小程序模板網(wǎng)

微信小程序 - http請(qǐng)求封裝

發(fā)布時(shí)間:2017-11-29 18:09 所屬欄目:小程序開(kāi)發(fā)教程

示例代碼 wx.request({ url: 'test.php', //僅為示例,并非真實(shí)的接口地址 data: { x: '' , y: '' }, method:'POST', header: { 'content-type': 'application/json' }, success: function(res) { console.log(res.d ...

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

以上為小程序的基本http請(qǐng)求代碼,實(shí)際代碼中如果每次這樣來(lái)寫(xiě)是比較繁瑣的,那我們就來(lái)做一下封裝。


那代碼中我們比較關(guān)注什么?

1.請(qǐng)求的參數(shù),訪問(wèn)的接口
2.GET/POST...請(qǐng)求方式
3.請(qǐng)求參數(shù)統(tǒng)一處理(比如:加密、設(shè)置公共參數(shù)...)
4.請(qǐng)求成功返回的數(shù)據(jù)(比如:解密、抽離邏輯層數(shù)據(jù))
5.請(qǐng)求失敗反饋

我們不關(guān)注什么?

1.請(qǐng)求url(一般固定的配置在某個(gè)地方)
2.根據(jù)不同的接口規(guī)則做不同的請(qǐng)求參數(shù)(比如:參數(shù)加密等)
...

讓我們代碼實(shí)操
  1. network.js
var API_URL = 'http://localhost/loverule/api/api.php'

var requestHandler = {
    params:{},
    success: function(res){
        // success
    },
    fail: function() {
        // fail
    },
}

//GET請(qǐng)求
function GET(requestHandler) {
    request('GET',requestHandler)
}
//POST請(qǐng)求
function POST(requestHandler) {
    request('POST',requestHandler)
}

function request(method,requestHandler) {
    //注意:可以對(duì)params加密等處理
    var params = requestHandler.params;

    wx.request({
      url: API_URL,
      data: params,
      method: method, // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
      // header: {}, // 設(shè)置請(qǐng)求的 header
      success: function(res){
        //注意:可以對(duì)參數(shù)解密等處理
        requestHandler.success(res)
      },
      fail: function() {
        requestHandler.fail()
      },
      complete: function() {
        // complete
      }
    })
}

module.exports = {
  GET: GET,
  POST: POST
}
  1. 頁(yè)面中調(diào)用(以GET請(qǐng)求為例)
    //導(dǎo)入js
    var network = require("../../utils/network.js")

    //寫(xiě)入?yún)?shù)
    var params = new Object()
    params.api_name = "api_user_login"
    params.account = "hanqing"
    params.password = "123456"

    //發(fā)起請(qǐng)求
    network.GET(
    {
        params: params,
        success: function (res) {
          console.log(res)
          //拿到解密后的數(shù)據(jù),進(jìn)行代碼邏輯

        },
        fail: function () {
          //失敗后的邏輯

        },
    })


易優(yōu)小程序(企業(yè)版)+靈活api+前后代碼開(kāi)源 碼云倉(cāng)庫(kù):starfork
本文地址:http://22321a.com/wxmini/doc/course/17993.html 復(fù)制鏈接 如需定制請(qǐng)聯(lián)系易優(yōu)客服咨詢:800182392 點(diǎn)擊咨詢
QQ在線咨詢