mpvue小程序开发

查阅资料,看官方文档,知道mpvue是一个使用 Vue.js 开发小程序的前端框架(美团的开源项目)。框架基于 Vue.js 核心,mpvue 修改了 Vue.js 的 runtime 和 compiler 实现,使其能够运行在小程序环境中,从而为小程序开发引入了整套 Vue.js 开发体验。html

mpvue你可使用你熟悉的vue框架语法,双向绑定让你不用再使用wx的this.setData了,你可使用npm方便的引入第三方了,真的是贫穷限制了个人想象力啊。我的感受mpvue比wepy更加简单,上手更加方便,mpuve五分钟教程快速构建。前端

 1 # 全局安装 vue-cli
 2 $ npm install --global vue-cli
 3 
 4 # 建立一个基于 mpvue-quickstart 模板的新项目
 5 $ vue init mpvue/mpvue-quickstart my-project
 6 
 7 # 安装依赖
 8 $ cd my-project
 9 $ npm install
10 # 启动构建
11 $ npm run dev

须要注意的是:我在vue

npm install --global vue-cli

安装时。遇到了报错Error: EACCES: permission denied, access '/usr/local/lib/node_modules/vue-cli/node_modules/asn1'node

很明显这个错误由于权限不够。ios

解决办法:运行命令前加sudo 在管理员权限之下执行。git

建立新项目时我选择了Vuex,可是ESlint(代码检查)没有选。不喜欢检测空格和;的规范github

完成建立新项目后用微信开发者工具打开页面是这样的vue-cli

封装api和http请求(这里使用的是flyio,除了请求取消,其余功能基本类似axios,大小只有4kb,是axios的三分之一)npm

参见官网连接https://wendux.github.io/dist/#/doc/flyio/readmejson

使用fiyio的方法是:
package.json加入依赖

或者npm install flyio

下载以后咱们会在ppackage.json中看到

在微信小程序中引入flyio

var Fly=require("../lib/wx") //wx.js为您下载的源码文件
// var Fly=require("flyio/dist/npm/wx") //npm引入方式
var fly=new Fly(); //建立fly实例

//添加拦截器
fly.interceptors.request.use((config,promise)=>{
    //给全部请求添加自定义header
    config.headers["X-Tag"]="flyio";
    return config;
})
//配置请求基地址
fly.config.baseURL="https://wendux.github.io/"
...

Page({
  //事件处理函数
  bindViewTap: function() {
    //调用
    fly.get("http://10.10.180.81/doris/1/1.0.0/user/login",{xx:6}).then((d)=>{
      //输出请求数据
      console.log(d.data)
      //输出响应头
      console.log(d.header)
    }).catch(err=>{
      console.log(err.status,err.message)
    })
    ...
  })
})

若是你是npm添加使用

var Fly=require("flyio/dist/npm/wx") //npm引入方式

使用这种方式

接下来:将flyio封装的请求和项目api做为组件库挂载在原型对象上,这样不用每一个vue单页面都import 封装的js,直接使用this.$http调用方法。

挂载的方式以下:

补充下使用mpvue须要注意的地方(具体参考官方文档)

1.新增页面须要npm run dev重启一下。

2.小程序里全部的 BOM/DOM 都不能用,也就是说 v-html 指令不能用。

3.暂不支持在组件上使用 Class 与 Style 绑定,须要在组件内部书写。

4.mpvue 能够支持小程序的原生组件,好比: picker,map 等,须要注意的是原生组件上的事件绑定,须要以 vue 的事件绑定语法来绑定,如 bindchange="eventName" 事件,须要写成 @change="eventName"。

5.mpvue 建议使用 v-model.lazy 绑定方式以优化性能,此外 v-model 在老基础库下输入框输入时可能存在光标重设的问题。 

6.写页面跳转时候传入动态参数,须要写成:url,如:<navigator url="'../test/main?id='+id hover-class="none""。

7.经过 this.$root.$mp.query 进行获取小程序在 page onLoad 时候传递的 options。经过 this.$root.$mp.appOptions 进行获取小程序在 app onLaunch/onShow 时候传递的 options。

8.使用this.$root.$mp.query获取参数须要在monted中获取,在created中会报Cannot read property 'query' of undefined 。

相关文章
相关标签/搜索