微信小程序 - 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.根据不同的接口规则做不同的请求参数(比如:参数加密等)
...

让我们代码实操
  1. 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 () {
          //失败后的逻辑

        },
    })
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,869评论 18 139
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 11,123评论 6 13
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,090评论 25 708
  • 特岗三年 文/尘一粒 当收拾清理办公桌的时候,我才意识到—...
    尘一粒W阅读 910评论 0 7
  • 记得去年 多做自己主动性工作,有开头有中心,时间不够用,参与度得提高。 正式入职是七月五号,到现在已经过了半年,
    大李的日常随笔阅读 205评论 0 0