首頁 >微信小程式 >小程式開發 >微信小程式的http請求封裝詳解

微信小程式的http請求封裝詳解

PHPz
PHPz原創
2017-04-02 14:49:322529瀏覽

微信小程式  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
}

頁面中呼叫(以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請求封裝詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn