iKcamp出品|微信小程序|工具安装+目录说明|基于最新版1.0开发者工具初中级教程分享

iKcamp官网:http://www.ikcamp.comcss

访问官网更快阅读所有免费分享课程:《iKcamp出品|全网最新|微信小程序|基于最新版1.0开发者工具之初中级培训教程分享》。
包含:文章、视频、源代码html

第一章:小程序初级入门教程

工具安装

在上一节第 8 步所展现的页面中,能够点击 开发者工具 直接进入到下载页面,也能够直接访问 官网下载地址。而后根据本身的设备选择相应的下载
安装过程再也不复述,一路默认。 前端

下载开发工具node

§ 小程序工具起手

此教程选择的工具为 mac 平台版本,没差web

  1. 打开安装好的 微信web开发者工具 ,须要用 管理员开发者 的微信帐号扫码登陆。管理员帐号 是上一节第 6 步中注册 appID 时,绑定的微信帐号。开发者帐号可在上一节第 8 步中的 添加开发者 中设置

  1. 登陆成功后,选择 本地小程序项目,而后 添加项目

  1. 若是没有注册 appID,也能够开发小程序项目,但部分功能会受限,好比在手机上预览。在这里,咱们已经有了 appID

  1. 添加成功后,咱们的项目会在 微信web开发者工具 中自动打开并启动,能够在此工具中对代码进行修改、调试、断点、预览,文件有修改的话,项目会实时更新。

目录说明

项目生成后,会看到以下结构的目录文件:express

├─ pages/
│   ├─ index/
│       ├─ index.js
│       ├─ index.wxml
│       ├─ index.wxss
│   ├─ logs/
│       ├─ logs.js
│       ├─ logs.json
│       ├─ logs.wxml
│       ├─ logs.wxss
├── utils/             
│   ├─ util.js
├── app.js                  // 必备文件  
├── app.json                // 必备文件
├── app.wxss

先看下最外层的三个文件:app.jsapp.jsonapp.wxss

  1. app.js
    小程序的主入口文件,相似于咱们在模块加载器时代(requirejs/seajs)经常会码一个 main.js 来做为程序的启动入口。若是你有接触过 node - express 技术栈,理解起来会更贴切。注意:<span style="color:red">文件名不可更改</span>

咱们能够在 app.js 里面对小程序在不一样生命周期段进行处理,设置小程序里面的 全局变量(好比只请求一次公用的数据,让全部的页面都能用)。
微信平台 app.js 说明文档

编程

  1. app.json
    小程序的全局配置文件,好比设置小程序有哪几个页面组成(目前是 indexlogs)、窗口表现(背景色等)、设置网络超时时间、设置导航条样式等背景色。注意:<span style="color:red">该文件不可添加任何注释内容</span>

微信平台 app.json 配置文档

json

  1. app.wxss
    小程序的全局样式文件,在小程序中,全部的样式文件再也不是 .css 后缀,全都须要以 .wxss 做为后缀。与传统的 css 样式相比,wxss 支持 @import 样式导入和像素单位自适应。

独立页面中的局部样式,请书写在相对的页面文件夹中,后面会有说明。
微信平台 app.wxss 样式说明文档

小程序

小程序的页面文件

app.json 文件中配置了当前小程序的两个页面 pages/index/indexpages/logs/logs,能够看到,其实就是 文件的路径+文件名 组成。若是增长一个页面,须要在参数 pages 中把页面的地址配置进去。微信小程序

细心的同窗可能已经发现一个现象,每一个页面文件夹,与里面的文件,名字都同样同样滴。是的,通常状况下,一个完整的页面须要 jswxss(css)wxml(html) 组成。
好比 index 页面,若是须要对 index 页面进行一些独立的配置,须要像 logs 同样,增长 index.json 文件来保存配置信息。

来看下 wxml 文件与 html 文件的区别

<!--index.wxml-->
<view class="container">
  <view class="userinfo">
    <button wx:if="{{!hasUserInfo && canIUse}}" open-type="getUserInfo" bindgetuserinfo="getUserInfo"> 获取头像昵称 </button>
    <block wx:else>
      <image bindtap="bindViewTap" class="userinfo-avatar" src="{{userInfo.avatarUrl}}" background-size="cover"></image>
      <text class="userinfo-nickname">{{userInfo.nickName}}</text>
    </block>
  </view>
  <view class="usermotto">
    <text class="user-motto">{{motto}}</text>
  </view>
</view>

传统的 html 文件由各类各样的标签组成,而在 wxml 中,可用的标签元素并很少,能够看到这里涉及到了 viewimagetext标签。

  • view 至关于 div,你能够这么去理解。
  • image 至关于 img,这个应该都懂了。
  • text 很明显,用来标注文本的标签,既然是 文本,确定是 行级元素 了。

还有一些内置好的组件标签,自带样式和特性,详见 官方文档

页面样式表 index.wxss

做用域只在当前页面生效,它能够覆盖 app.wxss 里面的样式规则。能够看到,与平时咱们用的样式文件基本没差:

/**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;
}

页面脚本文件 index.js

app.js 同样,包含了一个页面的生命周期,声明并处理数据,响应页面交互事件等。

//index.js
//获取应用实例
const app = getApp()

Page({
  data: {
    motto: 'Hello World',
    userInfo: {},
    hasUserInfo: false,
    canIUse: wx.canIUse('button.open-type.getUserInfo')
  },
  //事件处理函数
  bindViewTap: function() {
    wx.navigateTo({
      url: '../logs/logs'
    })
  },
  onLoad: function () {
    if (app.globalData.userInfo) {
      this.setData({
        userInfo: app.globalData.userInfo,
        hasUserInfo: true
      })
    } else if (this.data.canIUse){
      // 因为 getUserInfo 是网络请求,可能会在 Page.onLoad 以后才返回
      // 因此此处加入 callback 以防止这种状况
      app.userInfoReadyCallback = res => {
        this.setData({
          userInfo: res.userInfo,
          hasUserInfo: true
        })
      }
    } else {
      // 在没有 open-type=getUserInfo 版本的兼容处理
      wx.getUserInfo({
        success: res => {
          app.globalData.userInfo = res.userInfo
          this.setData({
            userInfo: res.userInfo,
            hasUserInfo: true
          })
        }
      })
    }
  },
  getUserInfo: function(e) {
    console.log(e)
    app.globalData.userInfo = e.detail.userInfo
    this.setData({
      userInfo: e.detail.userInfo,
      hasUserInfo: true
    })
  }
})

下期更新内容:小程序初级入门教程-小试牛刀+发布流程

iKcamp原创新书《移动Web前端高效开发实战》已在亚马逊、京东、当当开售。


相关文章:
据说 2017 你想写前端?
前端开发者指南(2017)
翻译连载 |《你不知道的JS》姊妹篇 | JavaScript 轻量级函数式编程

iKcamp最新活动

报名地址:http://www.huodongxing.com/ev...

相关文章
相关标签/搜索