千家信息网

微信小程序中怎么实现http请求封装

发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,本篇内容介绍了"微信小程序中怎么实现http请求封装"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!微
千家信息网最后更新 2025年01月21日微信小程序中怎么实现http请求封装

本篇内容介绍了"微信小程序中怎么实现http请求封装"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

微信小程序 http请求封装

示例代码

wx.request({ url: 'test.php', //仅为示例,并非真实的接口地址 data: {   x: '' ,   y: '' }, method:'POST', header: {   'content-type': 'application/json' }, success: function(res) {  console.log(res.data) }, fail: function( res ) {   fail( res );  }})

以上为小程序的基本http请求代码,实际代码中如果每次这样来写是比较繁琐的,那我们就来做一下封装。

那代码中我们比较关注什么?

1.请求的参数,访问的接口
2.GET/POST...请求方式
3.请求参数统一处理(比如:加密、设置公共参数...)
4.请求成功返回的数据(比如:解密、抽离逻辑层数据)
5.请求失败反馈

我们不关注什么?

1.请求url(一般固定的配置在某个地方)
2.根据不同的接口规则做不同的请求参数(比如:参数加密等)
...

让我们代码实操

network.js

var API_URL = 'http://localhost/loverule/api/api.php'var requestHandler = {  params:{},  success: function(res){    // success  },  fail: function() {    // fail  },}//GET请求function GET(requestHandler) {  request('GET',requestHandler)}//POST请求function POST(requestHandler) {  request('POST',requestHandler)}function request(method,requestHandler) {  //注意:可以对params加密等处理  var params = requestHandler.params;  wx.request({   url: API_URL,   data: params,   method: method, // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT   // header: {}, // 设置请求的 header   success: function(res){    //注意:可以对参数解密等处理    requestHandler.success(res)   },   fail: function() {    requestHandler.fail()   },   complete: function() {    // complete   }  })}module.exports = { GET: GET, POST: POST}

1.页面中调用(以GET请求为例)

  //导入js  var network = require("../../utils/network.js")  //写入参数  var params = new Object()  params.api_name = "api_user_login"  params.account = "hanqing"  params.password = "123456"  //发起请求  network.GET(  {    params: params,    success: function (res) {     console.log(res)     //拿到解密后的数据,进行代码逻辑    },    fail: function () {     //失败后的逻辑    },  })

"微信小程序中怎么实现http请求封装"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

0