前言前端
最近都在研究小程序了,我能够的!vue
需求json
以前都是用vue来开发项目的,接口模块我特地封装了一下。感受也能够记录一下小程序
小程序的接口虽然说简单,可是重复调用那么多,显得不专业(一本正经的胡说八道)api
还有一篇,小程序遇到了的那些坑和小技巧)待续服务器
1、小程序接口请求流程微信
简单的画了一个流程图微信开发
2、域名配置app
必定要配置https,小程序上配置的域名必须是域名备案的,还有必定服务器要TLS1.2以上函数
三、打开微信开发者工具,打开你的项目,点开详情。确认一下域名是否一一匹对。否则会编译失败的哦
4、在你的项目文件utils 文件中新建api.js http.js
5、http.js 代码(复制过去就能够了)
module.exports = { http(url, method, params) { let token = 'token' // 获取token,自行获取token和签名,token和签名表示每一个接口都要发送的数据 let sign = 'sign' // 获取签名 (后台怎么定义的,就传什么) let data = { token, sign } if (params.data) { // 在这里判断一下data是否存在,params表示前端须要传递的数据,params是一个对象,有三组键值对,data:表示请求要发送的数据,success:成功的回调,fail:失败的回调,这三个字段可缺可无,其他字段会忽略 for (let key in params.data) { // 在这里判断传过来的参数值为null,就删除这个属性 if (params.data[key] == null || params.data[key] == 'null') { delete params.data[key] } } data = { ...data, ...params.data } } wx.request({ url: '你配置的域名' + url, // 就是拼接上前缀,此接口域名是开放接口,可访问 method: method == 'post' ? 'post' : 'get', // 判断请求类型,除了值等于'post'外,其他值均视做get 其余的请求类型也能够本身加上的 data, header: { 'content-type': 'application/json' }, success(res) { params.success && params.success(res.data) }, fail(err) { params.fail && params.fail(err) } }) } }
6、api.js(再次复制代码 就能够了)
// 在这里面定义全部接口,一个文件管理全部接口,易于维护 import { http } from './http'; // 引入刚刚封装好的http模块,import属于ES6的语法,微信开发者工具必须打开ES6转ES5选项 function femaleNameApi(params) { // 请求随机古诗词接口 http('project/projectInfos', 'get', params) // 接口请求的路由地址以及请求方法在此处传递 } // 每个接口定义一个函数,而后暴露出去,供逻辑代码调用 function novelApi(params) { // 小说推荐接口 http('/novelApi', 'get', params) } export default { // 暴露接口 femaleNameApi, novelApi }
7、在index.js 调用(你想在哪里用就在哪里用)
//index.js import http from '../../utils/api' // 引入api接口管理文件 Page({ onLoad: function () { this.getData() }, getData(){ http.femaleNameApi({ // 调用接口,传入参数 data: { token: '470712FF0FE2392D6CB6D8A6560805CC' }, success: res => { console.log('接口请求成功', res) this.setData({ femaleList: res.data }) }, fail: err => { console.log(err) } }) } })
8、打开控制台
若是你这样的错
忘记说了showRequestInfo() 这个了(一开始,觉得是api 接口),直接在控制台输入这个方法就能够了,能够看到错误信息详情
那说明大家的服务器要有证书,并且TLS版本要大于等于1.2
(我把我后台逼疯了,哈哈哈哈哈哈哈)
若是你是这样的,恭喜你接口成功了呢
9、Fannie式总结
以上的两个文件,算是接口封装的模板,你放在哪个项目里面均可以这样配置
有一点一劳永逸的意思
可是它封装的不够完美
没有个人vue项目封装的好,改天再改造一下
但愿对你有帮助,拜拜咯!