微信小程序網(wǎng)絡(luò)封裝(簡(jiǎn)單高效)
廢話引言
小程序雖然出世很久了,但一直沒(méi)怎么接觸到小程序開(kāi)發(fā)。吉他興趣班老師想弄一個(gè)小程序發(fā)布課程信息和打卡功能,作為IT一員就自愿加入了這個(gè)小程序開(kāi)發(fā)小組中。雖然小程序面向的是前端工程師,但作為移動(dòng)端程序猿感覺(jué)甚是友好,加上有點(diǎn)前端基礎(chǔ)就更是覺(jué)得入手很easy啦。
微信小程序的網(wǎng)絡(luò)請(qǐng)求很便捷,直接調(diào)用就可以了。但最好還是根據(jù)需求,處理一些參數(shù)回調(diào)信息,進(jìn)行二次封裝,為整個(gè)小程序應(yīng)用直接提供調(diào)方法接口豈不是更好?
利用網(wǎng)絡(luò)請(qǐng)求的一貫思維,分三個(gè)回調(diào):onStart:開(kāi)始請(qǐng)求, onSuccess:請(qǐng)求成功回調(diào), onFailed:請(qǐng)求失敗回調(diào), 意思就是字面意思~
netUtil.js 網(wǎng)絡(luò)請(qǐng)求工具封裝
在utils目錄下創(chuàng)建一個(gè)netUtil.js文件
/**
* 供外部post請(qǐng)求調(diào)用
*/
function post(url, params, onStart, onSuccess, onFailed) {
request(url, params, "POST", onStart, onSuccess, onFailed);
}
/**
* 供外部get請(qǐng)求調(diào)用
*/
function get(url, params, onStart, onSuccess, onFailed) {
request(url, params, "GET", onStart, onSuccess, onFailed);
}
/**
* function: 封裝網(wǎng)絡(luò)請(qǐng)求
* @url URL地址
* @params 請(qǐng)求參數(shù)
* @method 請(qǐng)求方式:GET/POST
* @onStart 開(kāi)始請(qǐng)求,初始加載loading等處理
* @onSuccess 成功回調(diào)
* @onFailed 失敗回調(diào)
*/
function request(url, params, method, onStart, onSuccess, onFailed) {
onStart(); //request start
wx.request({
url: url,
data: dealParams(params),
method: method,
header: { 'content-type': 'application/json' },
success: function (res) {
if (res.data) {
/** start 根據(jù)需求 接口的返回狀態(tài)碼進(jìn)行處理 */
if (res.data.error_code == 0) {
onSuccess(res.data); //request success
} else {
onFailed(res.data.msg); //request failed
}
/** end 處理結(jié)束*/
}
},
fail: function (error) {
onFailed(""); //failure for other reasons
}
})
}
/**
* function: 根據(jù)需求處理請(qǐng)求參數(shù):添加固定參數(shù)配置等
* @params 請(qǐng)求參數(shù)
*/
function dealParams(params) {
return params;
}
module.exports = {
postRequest: post,
getRequest: get,
}
小案例使用說(shuō)明:笑話大全接口
簡(jiǎn)要描述:用戶注冊(cè)接口
請(qǐng)求URL:http://v.juhe.cn/joke/content/list.php
請(qǐng)求方式:GET
參數(shù):
| 參數(shù)名 | 必選 | 類型 | 說(shuō)明 |
|---|---|---|---|
| sort | 否 | string | 降序“des”,升序“asc” |
| page | 否 | int | 頁(yè)數(shù),默認(rèn)1 |
| pageSize | 否 | string | 默認(rèn)每頁(yè)加載20條數(shù)據(jù) |
| time | 是 | string | 時(shí)間戳10位 |
| key | 是 | string | appkey |
返回示例
{
"error_code": 0,
"reason": "Success",
"result": {
"data": [
{
"content": "某先生是地方上的要人。一天,他像往常一樣在書(shū)房里例覽當(dāng)日?qǐng)?bào)紙,突然對(duì)妻子大聲喊道:喂,安娜,你看到今天早報(bào)上的流言蜚語(yǔ)了嗎?真可笑!他們說(shuō),你收拾行裝出走了。你聽(tīng)見(jiàn)了嗎?安娜、你在哪兒?安娜???!",
"hashId": "90B182FC7F74865B40B1E5807CFEBF41",
"unixtime": 1418745227,
"updatetime": "2014-12-16 23:53:47"
},
{
"content": "有一天我看著報(bào)紙,小聲嘟囔著一篇文章的題目鳥(niǎo)兒也有外語(yǔ),丈夫聽(tīng)了對(duì)了一句:鳥(niǎo)兒當(dāng)然也有‘外遇'。原來(lái)丈夫聽(tīng)錯(cuò)了,我笑得前仰后合。",
"hashId": "206F5C52FD2ED94772CBC66C8AC61F2A",
"unixtime": 1418745227,
"updatetime": "2014-12-16 23:53:47"
}
]
}
}
小程序頁(yè)面js文件中引入netUtil
var netUtil = require("../../utils/network.js"); //require引入
Page({
data: {
jokeList: {}
},
onLoad: function (options) {
var url = "http://v.juhe.cn/joke/content/list.php";
var params = {
sort: "",
page: 1,
pagesize: 5,
time: "1418816972",
key: "746dfdb4cd8445d30a8f915fd2b5f76b",
}
netUtil.getRequest(url, params, this.onStart, this.onSuccess, this.onFailed); //調(diào)用get方法情就是戶數(shù)
},
onStart: function () { //onStart回調(diào)
wx.showLoading({
title: '正在加載',
})
},
onSuccess: function (res) { //onSuccess回調(diào)
wx.hideLoading();
this.setData({
jokeList: res.result.data //請(qǐng)求結(jié)果數(shù)據(jù)
})
},
onFailed: function (msg) { //onFailed回調(diào)
wx.hideLoading();
if (msg) {
wx.showToast({
title: msg,
})
}
},
})
在wxml文件中綁定請(qǐng)求的笑話大全列表:jokeList
<view>
<block wx:for="{{jokeList}}" wx:for-item="item" wx:key="idx">
<view class='joke_container'>
<text>{{item.content}}</text>
</view>
</block>
</view>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 微信小程序 數(shù)據(jù)封裝,參數(shù)傳值等經(jīng)驗(yàn)分享
- 微信小程序 使用picker封裝省市區(qū)三級(jí)聯(lián)動(dòng)實(shí)例代碼
- 微信小程序?qū)崿F(xiàn)自定義modal彈窗封裝的方法
- 微信小程序之網(wǎng)絡(luò)請(qǐng)求簡(jiǎn)單封裝實(shí)例詳解
- 微信小程序 es6-promise.js封裝請(qǐng)求與處理異步進(jìn)程
- 微信小程序 wx.request方法的異步封裝實(shí)例詳解
- 微信小程序 request接口的封裝實(shí)例代碼
- 微信小程序 http請(qǐng)求封裝詳解及實(shí)例代碼
- 微信小程序 封裝http請(qǐng)求實(shí)例詳解
- 詳解微信小程序網(wǎng)絡(luò)請(qǐng)求接口封裝實(shí)例
相關(guān)文章
微信小程序商城項(xiàng)目之側(cè)欄分類效果(1)
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崙?zhàn)商城系列之側(cè)欄分類效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04
JS關(guān)閉窗口時(shí)產(chǎn)生的事件及用法示例
這篇文章主要介紹了JS關(guān)閉窗口時(shí)產(chǎn)生的事件及用法,結(jié)合關(guān)閉窗口時(shí)提交評(píng)論的實(shí)例分析了javascript事件觸發(fā)機(jī)制及遮罩層實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-08-08
詳談js對(duì)url進(jìn)行編碼和解碼(三種方式的區(qū)別)
下面小編就為大家?guī)?lái)一篇詳談js對(duì)url進(jìn)行編碼和解碼(三種方式的區(qū)別)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08
JS偽繼承prototype實(shí)現(xiàn)方法示例
這篇文章主要介紹了JS偽繼承prototype實(shí)現(xiàn)方法,結(jié)合實(shí)例形式對(duì)比分析了基于prototype實(shí)現(xiàn)模擬繼承的相關(guān)操作技巧,需要的朋友可以參考下2018-06-06
js保留兩位小數(shù)使用toFixed實(shí)現(xiàn)
直接使用Math.round(x*100)存在一個(gè)問(wèn)題,有時(shí)會(huì)有很小的誤差,顯示很多位的小數(shù)位,如0.9996*100,就會(huì)變成99.96000000000001,我想要的在下面,感興趣的朋友可以參考下哈2013-07-07
JavaScript實(shí)現(xiàn)SHA-1加密算法的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)SHA-1加密算法的方法,實(shí)例分析了使用javascript實(shí)現(xiàn)SHA-1加密算法的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03
JS實(shí)現(xiàn)滑動(dòng)菜單效果代碼(包括Tab,選項(xiàng)卡,橫向等效果)
這篇文章主要介紹了JS實(shí)現(xiàn)滑動(dòng)菜單效果代碼,以實(shí)例形式實(shí)現(xiàn)了包括Tab,選項(xiàng)卡,橫向等效果,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-09-09

