一、什么是promise?
1.首先了解什么是promise?
Promise 是异步编程的一种解决方案:从语法上讲,promise是一个对象,从它可以获取异步操作的消息;从本意上讲,它是承诺,承诺它过一段时间会给你一个结果。promise有三种状态: pending(等待态),fulfiled(成功态),rejected(失败态);状态一旦改变,就不会再变。创造promise实例后,它会立即执行。
二、使用promise封装wx.request()(思路)
使用promise封装wx.request()
在根目录下创建http目录及api.js文件fetch.js以及http.js文件;
1、首先在env目录下创建index.js,里面配置开发环境并将其导出(配置不同的开发环境:开发环境、测试环境、生产环境)
三个环境也可以说是系统开发的三个阶段:开发->测试->上线,其中生产环境也就是通常说的真实环境。- 开发环境:开发环境是程序猿们专门用于开发的服务器,配置可以比较随意,为了开发调试方便,一般打开全部错误报告。
- 测试环境:一般是克隆一份生产环境的配置,一个程序在测试环境工作不正常,那么肯定不能把它发布到生产机上。
- 生产环境:是值正式提供对外服务的,一般会关掉错误报告,打开错误日志。三个环境也可以说是系统开发的三个阶段:开发->测试->上线,其中生产环境也就是通常说的真实环境。
2、在api.js中统一管理,请求的url地址(定义请求路径并抛出对象)
3、在fetch.js中用promise对wx.request()进行封装(封装wx.request()网络模块 、抛出一个函数 这个函数会返回一个promise对象)
4、在http.js,根据当前环境,设置相应的baseUrl, 引入fetch中封装好的promise请求,封装基础的get\post\put\upload等请求方法,设置请求体,带上token和异常处理等;
设置对应的方法并导出;(入口函数,引入环境变量,路径和方法在此处统一调用;确定当前环境、请求的函数,将封装好的方法抛出)
5、在全局app.js中(用require导入)导入http,注册到根组件,在具体页面导入(用getApp导入全局的app组件),并使用;
三、使用promise封装wx.request()(简单)
1.目录结构
在根目录下创建http目录及api.js、fetch.js和http.js。
在api.js中统一管理,请求的url地址。
module.exports={
"banner":"/h8/home/multidata"
}
在fetch.js中用promise对wx.request()进行封装。
module.exprots=(url,method,data)=>{
let p=new Promise((resolve,reject)=>{
wx.request({
url:url,
data:data,
method:method,
success(res){
resolve(res)
},
fail(err){
reject(err)
}
})
})
return p;
}
在hppt.js中,根据当前的环境,设置相应的baseUrl,引入在fetch中封装好的promise请求,包括要引入api。
const api=require('./api')
const fetch=require('./fetch')
let baseUrl="http://123.207.32.32:8080/api"
function banner(){
return fetch(baseUrl+api.banner,{},"get")
}
module.exports={
banner,
}
在全局app.js中导入http,注册到根组件中
const http=require('./http/http.js')
App({
http,
})
在具体要使用的轮播的组件是swiper.js中写
const app=getApp();
Page({
data:{
list:[],
},
onLoad:function(){
app.http.banner().then((res)=>{
this.serDate({
list:res.data.data.banner.list
})
})
}
})