1.美团工程师推出的基于Vue.js封装的用于开发小程序的框架
2.融合了原生小程序和Vue.js的特色
3.可彻底组件化开发css
1.组件化开发
2.完成的Vue.js开发体验(前提是熟悉Vue)
3.可以使用Vuex管理状态
4.Webpack构建项目
5.最终H5转换工具将项目编译成小程序识别的文件vue
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 启动初始化项目webpack
1.src/app.json 全局配置文件
2.src/App.vue 等同于原生小程序中的app.js, 可再次写小程序应用实例的声明周期 函数 || 全局样式(style中编写)
3.main.js应用入口文件, 声明组件类型,挂载组件ios
import Vue from 'vue'
import App from './App.vue'
// Vue.config.productionTip = false 默认为false,用于启动项目的时候提示信息,设置为false关闭提示
Vue.config.productionTip = true
// 这个值是为了与后面要讲的小程序页面组件所区分开来,由于小程序页面组件和这个App.vue组件的写法和引入方式是一致的,为了区分二者,须要设置mpType值
App.mpType = 'app'
// 生成Vue实例
const app = new Vue(App)
// 挂载组件
app.$mount()git
页面须要文件介绍github
import Vue from 'vue'
import Index from './index.vue'
const index = new Vue(Index)
index.$mount()web
{
"navigationBarTitleText": "主页",
"navigationBarBackgroundColor": "#8ed145"
}vue-router
1.在每一个组件中都须要使用: 组件实例.$mount() 去挂载当前组件,不然对应的页面不能生效
2.npm run dev 每次会从新打包dist文件,测试只能在小程序工具上
3.mpvue中绑定小程序原生事件不能使用bind + 事件名,须要使用@事件名 且要定义在methods中不然不生效
4.新建立的页面须要从新执行: npm run dev才能将新的页面打包到dist文件中vuex
**vue实例声明周期**
8.destroyed Vue 实例销毁后调用。调用后,Vue 实例指示的全部东西都会解绑定,全部的事件监听器会被移除,全部的子实例也会被销毁。 该钩子在服务器端渲染期间不被调用。vue-cli
后台
除了 Vue 自己的生命周期外,mpvue 还兼容了小程序生命周期,这部分生命周期钩子的来源于微信小程序的 Page, 除特殊状况外,不建议使用小程序的生命周期钩子。
vue-router
(1)wx.navigateTo() 保留当前页面,可回退
(2)wx.redirectTo() 不保留,不能回退
(3)wx.switchTab() 使用于tabBar页面
axios
gitHub地址
https://github.com/wendux/fly
使用步骤
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()
**原生小程序**
1)在data中初始化状态数据
2)修改状态: this.setData({key: value})
3)页面公共状态:
a.App程序实例的data中定义
b.获取状态数据: let datas = getApp()
c.修改状态数据: datas.data.xxx = value
4)或者利用storage本地存储
Mpvue
1)在组件中经过getApp没法拿到对应的数据
2)mpvue中支持vuex,因此可使用vuex集中管理状态
3)vuex几个重要的概念:
a.store对象
b.dispatch() 分发状态
c.actions 携带参与修改状态的数据,并触发mutations
d.mutations用于修改状态,并将状态交给store对象
e.getter 用于动态计算状态
1)原生小程序运行更稳定些, 兼容性好,mpvue可能在某些方面存在兼容性问题(vue-router)2)mpvue支持vue组件化开发. 效率更高,功能更强大(双向数据绑定, vuex)3)mpvue可基于webpack组件化, 工程化开发4)原生不支持npm安装包,不支持css预处理5)支持 computed 计算属性和 watcher 监听器;模板语法中只支持简单的 js 表达式。能够直接写 div 、span 等标签 computed 的写法6)以前会vue的工程师上手mpvue框架的成本较低