第一章: mpVue(Vue in Mini Program)


1.1 简介

  1. 美团工程师推出的基于Vue.js封装的用于开发小程序的框架
  2. 融合了原生小程序和Vue.js的特点
  3. 可完全组件化开发

1.2 特点

  1. 组件化开发
  2. 完成的Vue.js开发体验(前提是熟悉Vue)
  3. 可使用Vuex管理状态
  4. Webpack构建项目
  5. 最终H5转换工具将项目编译成小程序识别的文件

1.3 初始化项目

  1. npm install vue-cli -g 下载vue脚手架
  2. vue init mpvue/mpvue-quickstart my-project 初始化项目
  3. cd my-project 进入项目根目录
  4. npm install 根据package.json安装项目依赖包
  5. npm start || npm run dev 启动初始化项目

第二章 开启项目


2.1 注册小程序

  1. src/app.json 全局配置文件
  2. src/App.vue 等同于原生小程序中的app.js, 可再次写小程序应用实例的声明周期 函数 || 全局样式(style中编写)
  3. main.js应用入口文件, 声明组件类型,挂载组件

2.2 入口文件介绍

  1. import Vue from 'vue'
  2. import App from './App.vue'
  3. // Vue.config.productionTip = false 默认为false,用于启动项目的时候提示信息,设置为false关闭提示
    Vue.config.productionTip = true
  4. // 这个值是为了与后面要讲的小程序页面组件所区分开来,因为小程序页面组件和这个App.vue组件的写法和引入方式是一致的,为了区分两者,需要设置mpType值
    App.mpType = 'app'
  5. // 生成Vue实例
    const app = new Vue(App)
  6. // 挂载组件
    app.$mount()

2.3 编写页面 pages/index

2.3.1 页面需要文件介绍

  1. index.vue 等同于原生中的wxml + wxss + js

  2. main.js 当前组件页面的入口文件,用于生成当前组件实例,并挂载组件

  3. main.json 当前页面的局部配置文件(注意:index.vue组件最终会被转化为main.wxml以及main.wxss文件, 所以当前的json文件需命名main)

    1. src源文件

  1. 自动打包后的dist文件

2.4 注意事项

  1. 在每个组件中都需要使用: 组件实例.$mount() 去挂载当前组件,否则对应的页面不能生效
  2. npm run dev 每次会重新打包dist文件,测试只能在小程序工具上
  3. mpvue中绑定小程序原生事件不能使用bind + 事件名,需要使用@事件名 且要定义在methods中否则不生效
  4. 新创建的页面需要重新执行: npm run dev才能将新的页面打包到dist文件中

2.5 vue实例声明周期 && 小程序声明周期

2.5.1 vue实例声明周期

  1. beforeCreate 实例初始化之后,数据观测(data observer) 和 event/watcher 事件配置之前被调用。
  2. created 实例已经创建完成之后被调用。在这一步,实例已完成以下的配置:数据观测(data observer),属性和方法的运算, watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。
  3. beforeMount 在挂载开始之前被调用:相关的 render 函数首次被调用。
  4. mounted el 被新创建的 vm.$el 替换,并挂载到实例上去之后调用该钩子。
  5. beforeUpdate 数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。 你可以在这个钩子中进一步地更改状态,这不会触发附加的重渲染过程。
  6. updated 由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。
  7. beforeDestroy 实例销毁之前调用。在这一步,实例仍然完全可用。
    8.destroyed Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。 该钩子在服务器端渲染期间不被调用。

2.5.2 小程序应用App实例声明周期

  1. onLaunch: 小程序应用初始化
  2. onShow: 小程序启动获取后台进入前台
  3. onHide: 小程序应用从前台进入后台

 

2.5.3 小程序页面Page实例生命周期

  1. onLoad 监听页面加载
  2. onShow: 页面显示
  3. onReady: 监听页面初始化渲染完成
  4. onHide: 监听页面隐藏,注意当前页面实例依然存活
  5. onUnload: 监听页面卸载
  6. onPullDownRefresh: 监听用户下载动作
  7. onReachBottom: 监听用户上拉触底操作
  8. onShareAppMessage: 用户点击右上角分享功能
  9. onPageScroll: 页面滚动
  10. onTabItemTap: 当前是 tab 页时,点击 tab 时触发

2.5.4 注意事项

除了 Vue 本身的生命周期外,mpvue 还兼容了小程序生命周期,这部分生命周期钩子的来源于微信小程序的 Page, 除特殊情况外,不建议使用小程序的生命周期钩子。

第三章 mpvue中使用vue-router && axios


3.1 vue-router

  1. 在mpvue中对vue-router的支持不好,问题较多
  1. 进行页面跳转的是可使用小程序提供的API

    (1) wx.navigateTo() 保留当前页面,可回退

    (2) wx.redirectTo() 不保留,不能回退

    (3) wx.switchTab() 使用于tabBar页面

3.2 axios

  1. 小程序中不支持使用axios,会报错: XMLHttpRequest is not a constructor
  1. 原因: 小程序的环境和浏览器的环境不一样
  1. 解决方法: 使用其他库: flyio

3.3 fly使用教程

3.3.1 gitHub地址

https://github.com/wendux/fly

3.3.2 使用步骤

1) 下载: npm install flyio

2) 引入: import Fly from ‘flyio/dist/npm/wx’ 注意flyio支持很多环境下使用

3) 生成实例: let fly = new Fly

4) 配置: Vue.prototype.$fly = fly

5) 使用: 组件中 this.$fly.get()

第四章 mpvue VS 小程序 状态管理


1.1 原生小程序

1) 在data中初始化状态数据

2) 修改状态: this.setData({key: value})

3) 页面公共状态:

a. App程序实例的data中定义

b. 获取状态数据: let datas = getApp()

c. 修改状态数据: datas.data.xxx = value

4) 或者利用storage本地存储

1.2 Mpvue

1) 在组件中通过getApp无法拿到对应的数据

2) mpvue中支持vuex,所以可以使用vuex集中管理状态

3) vuex几个重要的概念:

a. store对象

b. dispatch() 分发状态

c. actions 携带参与修改状态的数据,并触发mutations

d. mutations用于修改状态,并将状态交给store对象

e. getter 用于动态计算状态

第五章 原生小程序 VS mpvue 对比总结


1) 原生小程序运行更稳定些, 兼容性好,mpvue可能在某些方面存在兼容性问题(vue-router)

2) mpvue支持vue组件化开发. 效率更高,功能更强大(双向数据绑定, vuex)

3) mpvue可基于webpack组件化, 工程化开发

4) 原生不支持npm安装包,不支持css预处理

5) 支持 computed 计算属性和 watcher 监听器;模板语法中只支持简单的 js 表达式。可以直接写 div 、span 等标签
computed 的写法

6) 之前会vue的工程师上手mpvue框架的成本较低

mpVue学习笔记整理的更多相关文章

  1. python学习笔记整理——字典

    python学习笔记整理 数据结构--字典 无序的 {键:值} 对集合 用于查询的方法 len(d) Return the number of items in the dictionary d. 返 ...

  2. Deep Learning(深度学习)学习笔记整理系列之(五)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  3. Deep Learning(深度学习)学习笔记整理系列之(八)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  4. Deep Learning(深度学习)学习笔记整理系列之(七)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  5. Deep Learning(深度学习)学习笔记整理系列之(六)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  6. Deep Learning(深度学习)学习笔记整理系列之(四)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  7. Deep Learning(深度学习)学习笔记整理系列之(三)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  8. Deep Learning(深度学习)学习笔记整理系列之(二)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 2013-04 ...

  9. Deep Learning(深度学习)学习笔记整理系列之(一)

    Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0  2013-0 ...

随机推荐

  1. NoSQL数据库技术实战-第1章 NoSQL的数据一致性 传统关系型数据库的ACID

    在看着章节的时候,我简单的回顾了一下关系型数据库的事务处理的ACID原则,其中原子性和持久性比较好理解.由于以前没有深入去研究.关于一致性和隔离性上我产生了疑问,在整理后分析如下:   一致性:书中所 ...

  2. 处理springboot OTS parsing error: Failed to convert WOFF 2.0 font to SFNT

    springboot项目中添加了字体等文件后,页面无法识别,浏览器调试窗口报错如下: Failed to decode downloaded font: http://localhost:8080/f ...

  3. C# List分组

    //分组 8个为一组 List<List<string>> ArrayList = sArray.Select((x, i) => new { Index = i, Va ...

  4. Golang ioutil.ReadDir 读取目录下的内容并排序

    之前写的https://www.cnblogs.com/pu369/p/10620731.html一文中,也有对slice的排序,但代码乱的自己也看不下去了. 参考https://blog.csdn. ...

  5. ACM之一个简单的数学问题

    一个简单的数学题 时间限制:3000 ms  |  内存限制:65535 KB 难度:3 描述 zyc最近迷上了数学,一天,dj想出了一道数学题来难住他.算出1/n,但zyc一时答不上来希望大家能编程 ...

  6. CDOJ 1132 酱神赏花 dp+单调栈降低复杂度+滚动数组

    酱神赏花 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 262143/262143KB (Java/Others) Submit St ...

  7. cogs908. 校园网

    908. 校园网 ★★   输入文件:schlnet.in   输出文件:schlnet.out   简单对比时间限制:1 s   内存限制:128 MB USACO/schlnet(译 by Fel ...

  8. python 面对对象 类(继承, 多态)

    继承,继承其它实例化样本的属性和方法,需要在声明里重新定义和使用 class School(object): def __init__(self, name, addr): self.name = n ...

  9. SQLite 使用主键,ROWID 及自增列

    SQLite 使用主键,ROWID 及自增列 之前关注过一些嵌入式数据库,倒时 SQLite 风头更劲,在 Android 上被应用,在 HTML5 中一些浏览器的 Local Database 的实 ...

  10. pytest.fixture和普通函数调用

    普通函数嗲用def one(): a="aaaaaaaaaaa" return a def test_one(): s=one() print (s) test_one() pyt ...