封装wx.request的原因是什么,怎样进行封装
Admin 2022-07-19 群英技术资讯 611 次浏览
为什么要封装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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
某些情况下需要在典型数据流外强制修改子代。要修改的子代可以是 React 组件实例,也可以是 DOM 元素。这时就要用到refs来操作DOM,本文详细的介绍一下使用,感兴趣的可以了解一下
node项目中如何优雅的修改node_modules的依赖库?下面本篇文章就来带大家优雅修改node_modules中依赖库的方法,希望对大家有所帮助!
目录正文npm2yarnpnpm总结正文大家最近是不是经常听到 pnpm,我也一样。今天研究了一下它的机制,确实厉害,对 yarn 和 npm 可以说是降维打击。那具体好在哪里呢? 我们一起来看一下。我们按照包管理工具的发展历史,从 npm2 开始讲起:npm2用 node 版本管理工具把 node 版本降到 4,那
这篇文章主要介绍了Nest.js 授权验证的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
这篇文章主要介绍了JavaScript的function函数详细,而我们的JavaScript脚本语言比较特殊,相对于C语言,它的参数是不需要数据类型加持的。返回值return,我就不过多描述,他是和 C语言通的,如果没写他就会自动返回undefined,下面一起来看看文章内容,需要的朋友可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008