示例代碼 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)做一下封裝。
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)求失敗反饋
1.請(qǐng)求url(一般固定的配置在某個(gè)地方)
2.根據(jù)不同的接口規(guī)則做不同的請(qǐng)求參數(shù)(比如:參數(shù)加密等)
...
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
}
//導(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 () {
//失敗后的邏輯
},
})
工作日 8:30-12:00 14:30-18:00
周六及部分節(jié)假日提供值班服務(wù)