学习微信小程序开发指南

作者: 抹香君 | 来源:发表于2016-11-25 09:57 被阅读98次

官方教程

本文档将带你创建完成一个微信小程序,并可以在手机上体验该小程序的实际效果。这个小程序的首页将会显示欢迎语以及当前用户的微信头像,点击头像,可以在新开的页面中查看当前小程序的启动日志。

1.获取微信小程序的 AppID
2.创建项目

项目创建成功后,我们就可以点击该项目,进入并看到完整的开发者工具界面,点击左侧导航,在「编辑」里可以查看和编辑我们的代码,在「调试」里可以测试代码并模拟小程序在微信客户端效果,在「项目」里可以发送到手机里预览实际效果。

3.编写代码

最关键的,是 app.js、app.json、app.wxss 这三个。其中:

  • .js 后缀的是脚本文件
  • .json 后缀的文件是配置文件
  • .wxss 后缀的是样式表文件。

微信小程序会读取这些文件,并生成小程序实例。

app.js

app.js 是小程序的脚本代码。我们可以在这个文件中监听并处理小程序的生命周期函数、声明全局变量。调用 MINA 提供的丰富的 API,如本例的同步存储及同步读取本地数据。

//app.js

App({

  onLaunch: function () {
      //调用API从本地缓存中获取数据
    var logs = wx.getStorageSync('logs') || []
    logs.unshift(Date.now())
    wx.setStorageSync('logs', logs)
  },

  getUserInfo:function(cb){
      var that = this;
    if(this.globalData.userInfo){
        typeof cb == "function" && cb(this.globalData.userInfo)
    }else{
          //调用登录接口
          wx.login({
            success: function () {
                  wx.getUserInfo({
                    success: function (res) {
                          that.globalData.userInfo = res.userInfo;
                          typeof cb == "function" && cb(that.globalData.userInfo)
                    }
                })
            } 
          });
    } 
  },

  globalData:{
      userInfo:null
  }   
})
app.json

app.json 是对整个小程序的全局配置。我们可以在这个文件中配置小程序是由哪些页面组成,配置小程序的窗口背景色,配置导航条样式,配置默认标题。注意该文件不可添加任何注释。

{

  "pages":[
      "pages/index/index",   
    "pages/logs/logs"
  ],

  "window":{
      "backgroundTextStyle":"light",
    "navigationBarBackgroundColor": "#fff",
    "navigationBarTitleText": "WeChat",
    "navigationBarTextStyle":"black"
  } 
}
app.wxss

app.wxss 是整个小程序的公共样式表。我们可以在页面组件的class属性上直接使用app.wxss中声明的样式规则。

.container {

    height: 100%;
      display: flex;
      flex-direction: column;
      align-items: center; 
      justify-content: space-between;
      padding: 200rpx 0;
      box-sizing: border-box;
}
4.创建页面

在这个案例里,我们有两个页面,index 页面和 logs 页面,即欢迎页和小程序启动日志的展示页,他们都在 pages 目录下。微信小程序中的每一个页面的【路径+页面名】都需要写在 app.json 的 pages 中,且 pages 中的第一个页面是小程序的首页。

每一个小程序页面是由同路径下同名的四个不同后缀文件的组成,如:index.js、index.wxml、index.wxss、index.json。.js 后缀的文件是脚本文件,.json 后缀的文件是配置文件,.wxss 后缀的是样式表文件,.wxml 后缀的文件是页面结构文件。

index.wxml是页面的结构文件:
<view class="container">
    <view bindtap="bindViewTap" class="userinfo"> 
        <image class="userinfo-avatar" 
               src="{{userInfo.avatarUrl}}" 
               background-size="cover"></image> 
        <text class="userinfo-nickname">{{userInfo.nickName}}</text> 
    </view> 
    <view class="usermotto"> 
        <text class="user-motto">{{motto}}</text> 
    </view>
</view>

本例中使用了view、image、text来搭建页面结构,绑定数据和交互处理函数。

index.js 是页面的脚本文件

在这个文件中我们可以监听并处理页面的生命周期函数、获取小程序实例,声明并处理数据,响应页面交互事件等。

//index.js

//获取应用实例
var app = getApp()

Page({

  data: {
      motto: 'Hello World',
      userInfo: {}
  },

  //事件处理函数
  bindViewTap: function() {
    wx.navigateTo({
        url: '../logs/logs'
    })
   },

  onLoad: function () {
    console.log('onLoad')
    var that = this
    //调用应用实例的方法获取全局数据
    app.getUserInfo(function(userInfo){
        //更新数据
       that.setData({
            userInfo:userInfo
          })
    })
 }
})
index.wxss是页面的样式表
.userinfo {
    display: flex;
    flex-direction: column;
      align-items: center;
}

.userinfo-avatar {
    width: 128rpx;
    height: 128rpx;
    margin: 20rpx;
    border-radius: 50%;
}

.userinfo-nickname {
    color: #aaa;
}

.usermotto {
    margin-top: 200px;
}

页面的样式表是非必要的。当有页面样式表时,页面的样式表中的样式规则会层叠覆盖 app.wxss 中的样式规则。如果不指定页面的样式表,也可以在页面的结构文件中直接使用 app.wxss 中指定的样式规则。

index.json是页面的配置文件

页面的配置文件是非必要的。当有页面的配置文件时,配置项在该页面会覆盖 app.json 的 window 中相同的配置项。如果没有指定的页面配置文件,则在该页面直接使用 app.json 中的默认配置。

logs的页面结构
<!--logs.wxml--> 
<view class="container log-list"> 
    <block wx:for-items="{{logs}}" 
           wx:for-item="log"> 
        <text class="log-item">{{index + 1}}. {{log}}</text> 
    </block> 
</view>

logs 页面使用 <block/> 控制标签来组织代码,在 <block/> 上使用 wx:for-items 绑定 logs 数据,并将 logs 数据循环展开节点

logs页面脚本
//logs.js
var util = require('../../utils/util.js')
Page({
  data: {
      logs: []
  },

  onLoad: function () {
      this.setData({
          logs: (wx.getStorageSync('logs') || []).map(function (log) {
            return util.formatTime(new Date(log))
        })
      })
  }
})
运行结果
4.手机预览

开发者工具左侧菜单栏选择「项目」,点击「预览」,扫码后即可在微信客户端中体验。

不过,目前,预览和上传功能尚无法实现,需要等待微信官方的下一步更新。

微信应用开放的服务和组件包含如下:

  • 视图容器:视图(View)、滚动视图、Swiper
  • 基础内容:图标、文本、进度条
  • 表单组件:按钮、表单等等
  • 操作反馈
  • 导航
  • 媒体组建:音频、图片、视频。
  • 地图
  • 画布
  • 文件操作能力
  • 网络:上传下载能力、WebSocket
  • 数据:数据缓存能力
  • 位置:获取位置、查看位置
  • 设备:网络状态、系统信息、重力感应、罗盘
  • 界面:设置导航条、导航、动画、绘图等等
  • 开放接口:登录,包括签名加密,用户信息、微信支付、模板消息

相关文章

网友评论

    本文标题:学习微信小程序开发指南

    本文链接:https://www.haomeiwen.com/subject/hbvipttx.html