封装wx.request的原因是什么,怎样进行封装
Admin 2022-07-19 群英技术资讯 1156 次浏览
今天小编跟大家讲解下有关“封装wx.request的原因是什么,怎样进行封装”的内容 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了相关资料,希望小伙伴们看了有所帮助。为什么要封装wx.request?
因为我们请求接口时,有时候会请求一个接口的多个api,如果没有使用封装,那么我们编写代码会变得繁琐,并且也会导致性能问题。
封装的话,利于我们编写,并且提高用户体验和便于代码的修改。
当我们进行微信小程序的编写时,写到wx.request的时候,我想大家一定不陌生这种写法,和$.ajax的写法有相似之处。我们对于$.ajax的封装,想必大家并不陌生,这也就不难让我们联想到promise了。并且我们的微信小程序是支持es6语法,那promise就是一个好得封装选择。
我们找好了封装的理由和工具,那接下来就是针对wx.request这个棘手的东西进行封装了,首先在我们的开发工具中创建好文件
我们用一个大的文件夹将其包裹,在将内容分部处理

首先呢,在我们的fetch.js文件中,我们用promise来对wx.request进行封装:
//promise封装wx.request
module.exports=(url,data,method)=>{
//先定义promise
let promise=new Promise((resolve,reject)=>{
wx.request({
url:url,
data:data,
method:method,
//成功时执行
success(res){
resolve(res)
},
//失败时执行
fail(err){
reject(err)
},
})
})
//将promise推出去
return promise
}
然后,在我们的api.js文件中,我们可以将所需要请求的东西都放在这里,方便统一管理:
//接口的管理
module.exports={
"banner":"/h8/home/multidata"
}
最后,在我们的http.js文件中,将其集中起来使用:
//引入文件
const api=require("./api")
const fetch=require("./fetch")
//定义路径
let baseUrl="http://123.207.32.32:8000/api"
//导出内容
function banner(){
return fetch(baseUrl+api.banner,{},'get')
}
module.exports={
banner
}
封装好以后,我们需在全局app.js中引入才可使用:
const http=require('./http/http.js')
App({
http,
})
在文件中使用:
//引入app
const app=getApp()
Page({
data: {
list:[]
}
onLoad: function () {
app.http.banner().then(res)=>{
this.setData({
list:res.data.data.banner.list
})
}
}
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要给大家分享用jQuery怎样做一个九宫格抽奖功能的示例,九宫格抽奖功能在很多营销活动页面都能看到,还是比较常用的一个抽奖功能, 这篇主要是使用jQuery来实现的,文中代码具有一定的借鉴价值,感兴趣的朋友可以参考,希望大家阅读完这篇文章能有所收获,下面我们一起来学习一下吧。
本文我们来了解vant的picker组件的基本用法,下文示例对大家学习picker组件的使用有一定的帮助,需要的朋友可以参考。另外,本文还介绍了vant-ui的Field输入框和Picker结合使用时,如何绑定正确的id类型的值的问题,感兴趣的朋友也可以了解看看。
这篇文章主要介绍了React中的Context应用场景分析,Context 提供了一种在组件之间共享数据的方式,而不必显式地通过组件树的逐层传递 props,通过实例代码给大家介绍使用步骤,感兴趣的朋友跟随小编一起看看吧
这篇文章主要介绍了JavaScript设计模式之职责链模式,对设计模式感兴趣的同学,可以参考下
这篇文章我们来了解jQuery中如何实现修改display属性。这里我们可以使用CSS()方法来实现,具体的实现方法及代码如下,有需要的朋友可以参考,接下来就跟随小编来一起学习一下吧!
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008