微信小程序官方demo学习

  最近微信小程序很火,很喜欢那种轻应用,用完就走的理念。于是,下载好微信开发者工具,学习一下官方demo。

  体验下来,有类似react和vue的感觉,dom类似react那种组件的,data-binding和vue类似。

 

1 注册

到微信公众平台申请账号,https://mp.weixin.qq.com/,并且绑定管理员账户方便上机调试。

下载微信开发者工具,登录管理员微信账户。

 

2 初始

创建项目并初始化,输入第一步生成的AppID。

 

3 目录结构

其中,.js后缀的是脚本文件,.json后缀的文件是配置文件,.wxss后缀的是样式表文件。微信小程序会读取这些文件,并生成小程序实例。

 

4 全局配置 app.json

app.json决定页面文件的路径、窗口的title、底部tab的表现、网络超时时间、debug模式等,

下面是一个包含了所有配置项的app.json

{
  "pages": [
    "pages/index/index",
    "pages/logs/index"
  ],
  "window": {
    "navigationBarTitleText": "Demo"
  },
  "tabBar": {
    "list": [{
      "pagePath": "pages/index/index",
      "text": "首页"
    }, {
      "pagePath": "pages/logs/logs",
      "text": "日志"
    }]
  },
  "networkTimeout": {
    "request": 10000,
    "downloadFile": 10000
  },
  "debug": true
}

  

5 创建页面

每个页面包含4个文件 **.js、**.wxml、**.wxss、**.json

 

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 }) }) } })

  

getApp函数用来获取应用实例

 

page函数用来注册一个页面,其指定页面的初始数据、生命周期函数、事件处理函数和自己定义的函数,参数是一个对象。这里非常类似vue的。

 

index.wxss是页面的样式表

其中定义的规则会覆盖掉app.wxss中的样式规则

 

index.json是页面的配置文件

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

 

6 数据绑定

logs页面的结构

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

 

在block标签上使用wx:for来遍历logs数组,和vue的v-for一样,自定义指令。

 1 //logs.js
 2 var util = require('../../utils/util.js')
 3 Page({
 4   data: {
 5     logs: []
 6   },
 7   onLoad: function () {
 8     this.setData({
 9       logs: (wx.getStorageSync('logs') || []).map(function (log) {
10         return util.formatTime(new Date(log))
11       })
12     })
13   }
14 })

 

 

7 路由跳转

index.html页面的view标签的bindtap指令,绑定了bindViewTap函数,

 1 <!--index.wxml-->
 2 <view class="container">
 3   <view  bindtap="bindViewTap" class="userinfo">
 4     <image class="userinfo-avatar" src="{{userInfo.avatarUrl}}" background-size="cover"></image>
 5     <text class="userinfo-nickname">{{userInfo.nickName}}</text>
 6   </view>
 7   <view class="usermotto">
 8     <text class="user-motto">{{motto}}</text>
 9   </view>
10 </view>

 

 

页面跳转函数 wx.navigateTo()

1   bindViewTap: function() {
2     wx.navigateTo({
3       url: '../logs/logs'
4     })
5   }

 

8 调试

在调试栏目下面,在pc上面调试。

或者在项目栏目下面,点击预览,使用手机扫码预览。

posted @ 2017-01-10 21:50  弗朗西斯科  阅读(2658)  评论(0编辑  收藏  举报