美团小程序框架mpvue入门教程
安装vue-cli
npm install --g vue-cli
构建一个项目(期间会询问你是否使用一些工具/插件, 请根据自己的实际情况选择y或n,对于不懂得该选y还是n的,统统选n)
vue init mpvue/mpvue-quickstart test-wxapp
然后 进入我们创建的项目,并安装依赖
cd test-wxapp npm i
最后,在运行一下我们的开发服务
npm run dev
项目就跑起来了,这个时候,我们打开微信开发者工具,选择小程序,然后新建一个,项目目录填 我们项目目录下的dist目录 test-wxapp/dist,就可以看到效果了
我们先把/src/pages 下面的counter和logs两个文件夹删掉,只保留一个index ,顺便把 /src/components 文件夹下面的文件也全删掉,
然后把/src/main.js 里面的 config.pages里面多余的路由也删掉,只保留一条['^pages/index/main'],这样目前就只有个index页面,
然后我们打开/src/pages/index/index.vue 我们把里面多余的代码删掉,只保留一个基础骨架
<template> <div class="container"> 我是首页 </div> </template> <script> export default { data () { return { } }, methods: {}, created () {} } </script> <style scoped> </style>
tip
/src/utils/index.js
是一个公共函数库,里面只有一个简单的格式化日期函数,不要也可以删掉
到目前为止,一个干净的空项目就算是ok了,接下来我们来对微信原生的一些反人类的东西来做一下优化。
一、先用mptoast组件代替官方提供的wx.showToast, wx.showToast诸多不便我就不说了,关键是还有坑 小程序基础库比较低的,不管你怎么设置,总是会在弹窗里面加一个钩钩,有时候我想弹出错误消息也是打钩, 严重误导用户,字数上还有限制有带icon的不能超过7个字,你说说,你说说 7个字够干嘛的, 那我们来看看mptoast,据官方介绍mptoast具有轻量,配置少,冗余少,使用简单,可定制性强等特点
我们开根据官方介绍,从npm引入并配置
npm i vuex npm i mptoast -D
在项目的主配置文件(一般位于src/main.js)加入以下代码
import mpvueToastRegistry from 'mptoast/registry' mpvueToastRegistry(Vue)
在你需要弹窗的页面,引入组件,并注册,然后在页面内加入一个你注册的组件,就可以在js里面调用this.$mptoast()了, 以下是一个简单的实例
<template> <div> <-- 省略其他代码 --> <mptoast /> </div> </template> <script> import mptoast from 'mptoast' export default { components: { mptoast }, data () { return {} }, methods: { showToast () { this.$mptoast('我是提示信息') }, } } </script>
使用起来还是蛮简单的
二,用promise封装异步请求函数
在小程序的环境下面,要想发送一个外部请求,我们只能使用小程序官方提供的wx.request方法,
但是该方法的代码风跟跟Jquery年代的Ajax一样,都散靠回调来处理请求响应,如果有很多层回调,
就会有很多层嵌套,这让我们这些平时被async-await惯坏的人怎么接受?
所以,建完基本项目,我们要做的第一件事,就是用wx.request自己封装一个基于promise的异步请求方法。
我们先来看一下 wx.request的一个官方示例代码
wx.request({ url: 'test.php', //仅为示例,并非真实的接口地址 data: { x: '' , y: '' }, header: { 'content-type': 'application/json' // 默认值 }, success: function(res) { console.log(res.data) } })
可以看到,每次请求都要发送一大堆的东西,重点少这些东西里面,很可能对于一个项目来说, 绝大部分都是固定不变的,那这样,不是冗余了么。
tip: 更多wx.request参数,请参考 微信官方文档
我们分析一下,第一个参数是url,也就是我们请求的地址,这个应该是每次都不一样的,但是,不一样的应该也只是url的最后一部分,
接口名称的位置不一样,前面的服务器地址一般都是一样的,例如http://www.abc.com/api/member/login 对于同一个项目的所有接口
服务器地址http://www.abc.com/api/应该都是一样的,不一样的只是后妈的接口名称member/login,
那我们可以把url拆分成 服务器地址 + 接口名称,这样做也方便后期上线的时候,切换服务器地址。
第二个参数是请求的参数,请求的参数应该是每次都不一样的,所以这个我们就不做修改(事实上实际应用中,
经常有可能出现需要每个接口都带一个token的,我们也可以在这里统一加上去,不过这里就不做深入)
第三个参数是 请求头,这个一般同一个项目里面,这些都是一样的,所以我们就写死。 这里还有一个参数method请求方法,
这里因为使用默认值GET,所以就没列出,我们这边需要做设置,因为现在前后分离的模式,现在基本上大部分都是POST请求,所以我们这边也写死成method:'POST'
最后一个就是处理请求结果回调函数,示例里面只有一个请求成功的回调,其实我们应该再加一个请求实例的处理函数,
fail,而我们封装这个函数的重点,就是要用promise来处理这两个回调函数,使它们可以用async-await的语法
// 假设以下代码在 `/src/utils/requestMethod.js` let serverPath = 'http://www.abc.com/api/' export function post(url,body) { return new Promise((resolve,reject) => { wx.request({ url: serverPath + url // 拼接完整的url data: body method:'POST', header: { 'content-type': 'application/json' }, success(res) { resolve(res.data) // 把返回的数据传出去 }, fail(ret) { reject(ret) // 把错误信息传出去 } }) }) }
有了这样的封装,我们就可以在其他地方引入 上面这个文件,然后使用post函数请求
import {post} from '/src/utils/requestMethod.js' // 需要注意的是,这行代码必须要在async修饰的函数里面才能正确调用 let res = await post('member/login',{name:myname})
如果你觉得每次都要import这个文件很麻烦,那我们也可以把它挂在到Vue(mpvue)的原型(prototype)上,我们打开/src/main.js
文件,然后在里面加入以下代码
import {post} from '/src/utils/requestMethod.js' Vue.prototype.$post = post
这样,我们就可以在Vue(mpvue)的所有实例里面,直接使用 this.$post()来调用,只要一行代码,
// 这行代码同样需要在async修饰的函数里面才能正确调用 let res = await this.$post('member/login',{name:myname})