小程序文档整理之 -- 快速上手

2018-05-18 17:20:28

https://blog.csdn.net/bobobocai/article/details/78041483


首先安装node.js:node.js下载地址 
安装完成之后下载微信开发者工具,进行安装 微信开发者工具下载地址

文件结构

小程序文件结构很简单,一个主体app以及各个页面

这里写图片描述 
这里写图片描述

主体部分详解

app.json页面配置

注意!!:JSON文件中 //注释是错误的,这里加上只是为了方便理解内容,使用的话先要把所有注释都删除

{  "pages": [//(**必有)设置页面路径
    "pages/index/index",    "pages/order/order",    "pages/myself/myself"
  ],  "window": {  //设置默认页面的窗口表现
    "navigationBarBackgroundColor": "#fff", //导航栏背景颜色
    "navigationBarTitleText": "锄禾自然农场", //导航栏标题文字内容
    "navigationBarTextStyle":"black", //导航栏标题颜色,仅支持 black/white 
    //开启下拉刷新,下拉的时候可以看到背景颜色和下拉样式
    "enablePullDownRefresh": true, //是否开启下拉刷新
    "backgroundColor":"red",//窗口的背景色
    "backgroundTextStyle":"light"//下拉背景字体、loading 图的样式,仅支持 dark/light
  },  "tabBar": { //设置 tab 的表现
    "color":"red", //tab 上的文字默认颜色
    "selectedColor":"green", //tab 上的文字选中时的颜色
    "backgroundColor":"skyblue", //tab 的背景色
    "borderStyle":"black", //tabbar上边框的颜色, 仅支持 black/white
    "position":"bottom", //可选值 bottom、top
    "list": [ //(**必有)tab 的列表,详见 list 属性说明,最少2个、最多5个 tab
     {        "pagePath": "pages/index/index", //(**必有)页面路径,必须在 pages 中先定义
        "text": "首页", //(**必有) tab 上按钮文字
        "iconPath":"", //图片路径,icon 大小限制为40kb,建议尺寸为 81px * 81px,当 postion 为 top 时,此参数无效
        "selectedIconPath":"" //选中时的图片路径,icon 大小限制为40kb,建议尺寸为 81px * 81px ,当 postion 为 top 时,此参数无效
      },
      {        "pagePath": "pages/order/order",        "text": "订单"
      },
      {        "pagePath": "pages/myself/myself",        "text": "我的"
      }
    ]
  },  "networkTimeout": { //设置网络超时时间
    "request": 10000, //wx.request的超时时间,单位毫秒,默认为:60000
    "connectSocket":10000, //wx.connectSocket的超时时间
    "downloadFile": 10000, //wx.uploadFile的超时时间
    "uploadFile": 10000, //wx.downloadFile的超时时间
  },  "debug":true  //设置是否开启 debug 模式}1234567891011121314151617181920212223242526272829303132333435363738394041424344454647

app.js

在app.js中主要实现了注册一个小程序(页面名.js主要是注册页面),主要是调用了一个名为App() 函数,其用来注册一个小程序,接受一个 object 参数,其指定小程序的生命周期函数等。

App({  /**
   * 监听小程序初始化
   * 当小程序初始化完成时,会触发 onLaunch(全局只触发一次) 
   */  
  onLaunch: function(options) {
    path:   //打开小程序的路径 String  
    query:  //打开小程序的query Object  
    scene:  //打开小程序的场景值 Number  
    shareTicket:    //shareTicket,详见 获取更多转发信息 String  
    referrerInfo:   //当场景为由另一个小程序打开时,返回此字段 Object  
    referrerInfo.appId: //来源小程序的 appId String  
    referrerInfo.extraData: //来源小程序传过来的数据 Object  
  },  /**
   * 监听小程序显示    
   * 当小程序启动,或从后台进入前台显示,会触发 onShow
   * 参数和onLaunch一样
   */ 
  onShow: function(options) {
  },  /**
   * 监听小程序隐藏
   * 当小程序从前台进入后台,会触发 onHide
   */ 
  onHide: function() {
  },  /**
   * 错误监听函数
   * 当小程序发生脚本错误,或者 api 调用失败时,会触发 onError 并带上错误信息 
   */ 
  onError: function(msg) {
  },  /** 
   * 其他自定义函数,全局变量 
   */  
  globalData: {
    userName:"李四",  
    userAge:44
  }
})123456789101112131415161718192021222324252627282930313233343536373839404142

场景值 详见。 
getApp() 
小程序提供了全局的 getApp() 函数,可以获取到在其他页面的 js文件获取小程序实例。

// other.js
var appInstance = getApp()
console.log(appInstance.globalData.userName) //李四1234

注意: 
1、App() 必须在 app.js 中注册,且不能注册多个。 
2、不要在定义于 App() 内的函数中调用 getApp() ,使用 this 就可以拿到 app 实例。 
3、不要在 onLaunch 的时候调用 getCurrentPages(),此时 page 还没有生成。

app.wxss

全局样式组件,和css差不多 
直接参考官方文档即可 :官方文档

Page()

Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。

//index.jsPage({//页面的初始数据
  data: {
    text: "This is page data."
  },//1、生命周期函数/*
 *①监听页面加载
    1.一个页面只会调用一次,可以在 onLoad 中获取打开当前页面所调用的 query 参数
    2.参数: Object 其他页面打开当前页面所调用的 query 参数
*/

  onLoad: function(options) {

  },/*
 *②监听页面初次渲染完成
    1.一个页面只会调用一次,代表页面已经准备妥当,可以和视图层进行交互。
    2.对界面的设置如wx.setNavigationBarTitle请在onReady之后设置。详见生命周期
*/
  onReady: function() {

  },// ③监听页面显示--每次打开页面都会调用一次。
  onShow: function() {

  },// ④监听页面隐藏--当navigateTo或底部tab切换时调用。
  onHide: function() {

  },// ⑤监听页面卸载--当redirectTo或navigateBack的时候调用。
  onUnload: function() {

  },//2、页面相关事件处理函数 /*
 *①下拉刷新
     1. 监听用户下拉刷新事件。          
     2. 需要在app.json的window选项中或页面配置中开启enablePullDownRefresh。
     3. 当处理完数据刷新后,wx.stopPullDownRefresh可以停止当前页面的下拉刷新。
*/
  onPullDownRefresh: function() {

  },/*
 *②上拉触底     
    1.监听用户上拉触底事件。
    2.可以在app.json的window选项中或页面配置中设置触发距离onReachBottomDistance。
    3.在触发距离内滑动期间,本事件只会被触发一次。
 */
  onReachBottom: function() {

  },/*
 *③页面滚动
     1.监听用户滑动页面事件。 
     2.参数为 Object,包含以下字段:scrollTop
*/
   onPageScroll: function() {
        scrollTop:100px;//页面在垂直方向已滚动的距离(单位px)
  },/*
 *④用户转发
    1.只有定义了此事件处理函数,右上角菜单才会显示“转发”按钮 
    2.参数为 Object,包含以下字段: 
    3.此事件需要return 一个 Object,用于自定义转发内容
*/
  onShareAppMessage: function () {
      return {
          title: '转发标题',//默认值为当前小程序名称
          path: '/page/user?id=123'//转发路径,默认当前页面 path ,必须是以 / 开头的完整路径
      }
  },  // 其他--开发者可以添加任意的函数或数据到 object 参数中,在页面的函数中用 this 可以访问
  viewTap: function() {
    this.setData({
      text: 'Set some data for updating view.'
    }, function() {
      // this is setData callback
    })
  },
  customData: {
    hi: 'MINA'
  }
})
  • 2019-10-15 09:18:48

    腾讯 Android 面试笔试总结

    Activity中的几种启动模式 Android消息机制 IntentService 事件分发 Android性能优化、内存优化 内存优化 View的绘制 Eventbus原理 Rxjava的操作符有哪些,说说他们的作用 线程锁 锁方法和类对象啥的有啥区别 AsyncTask原理 说说MVP和MVVM的特点 Android中用到的观察者模式有哪些地方 说说google新出的Lifecycle框架 okhttp原理 Retrofit原理 RecyclerView源码、缓存分析 Binder机制 Android Jetpack Kotlin Activity中的几种启动模式

  • 2019-10-15 09:20:49

    SpringBoot注解梳理

    @SpringBootApplication:包含了@ComponentScan、@Configuration和@EnableAutoConfiguration注解。其中@ComponentScan让spring Boot扫描到Configuration类并把它加入到程序上下文。 @Configuration 等同于spring的XML配置文件;使用Java代码可以检查类型安全。 @EnableAutoConfiguration 自动配置。 @ComponentScan 组件扫描,可自动发现和装配一些Bean。 @Component可配合CommandLineRunner使用,在程序启动后执行一些基础任务。 @RestController注解是@Controller和@ResponseBody的合集,表示这是个控制器bean,并且是将函数的返回值直 接填入HTTP响应体中,是REST风格的控制器。 @Autowired自动导入。 @PathVariable获取参数。 @JsonBackReference解决嵌套外链问题。 @RepositoryRestResourcepublic配合spring-boot-starter-data-rest使用。

  • 2019-10-15 09:52:00

    动图解释递归,按值传递和按引用传递的区别,线性查找和二分查找,二叉查找树

    对于大部分人,数据结构一直是一个短板,当然我也是,不是学不会,而是容易忘,就拿最简单的排序来说吧,当时学习的时候明明已经弄得很清楚了,过了一段时间不用又忘记了,还要重新再看一遍,不知道有多少小伙伴和我有一样的烦恼。今天让我们用用动图的方式学习一下数据结构中的递归和二分查找吧,这种讲解方式非常生动,而且非常容易记住和理解。

  • 2019-10-16 21:02:47

    vue中mixins的详细分析一

    混入 (mixins): 是一种分发 Vue 组件中可复用功能的非常灵活的方式。混入对象可以包含任意组件选项。当组件使用混入对象时,所有混入对象的选项将被混入该组件本身的选项。