ReactNative fetch網(wǎng)絡(luò)請(qǐng)求封裝(GET,POST,圖片上傳)

1、前言

最近學(xué)習(xí)RN進(jìn)行到了網(wǎng)絡(luò)請(qǐng)求這一塊俺驶,便花了點(diǎn)時(shí)間把網(wǎng)絡(luò)請(qǐng)求封裝了一下纤房,這樣使用起來也方便

2却嗡、結(jié)構(gòu)

  • Connect.js 對(duì)NetUtils的二次封裝舶沛,將地址添加進(jìn)來,統(tǒng)一管理網(wǎng)絡(luò)請(qǐng)求
  • NetAddr.js 請(qǐng)求地址的存放
  • NetUtils.js get, post,圖片上傳的封裝
    image.png

3窗价、代碼

  • NetUtils.js代碼里都有注釋
export default class NetUtils{
    /**
     *  GET 請(qǐng)求
     */
    static get(url, params, success, fail, error){
        if (params) {
            let paramsArray = [];
            //拼接參數(shù)
            Object.keys(params).forEach(key => paramsArray.push(key + '=' + params[key]))
            if (url.search(/\?/) === -1) {
                url += '?' + paramsArray.join('&')
            } else {
                url += '&' + paramsArray.join('&')
            }
        }
        console.log(url, params)
        // fetch 請(qǐng)求
        fetch(url,{
            headers:{
              //看后臺(tái)需求決定配置參數(shù),例如我們后臺(tái)要求將appId放在這里請(qǐng)求
             // appId: '1234345656'
            },
        })
            .then(response=>response.json())//把response轉(zhuǎn)為json
            .then(responseJson=> { // 拿到上面的轉(zhuǎn)好的json
                console.log(responseJson) // 打印返回結(jié)果
                if (responseJson.code == 200){ // 200為請(qǐng)求成功
                   success && success(responseJson.data)
                }else {
                    fail && fail(responseJson.msg)//可以處理返回的錯(cuò)誤信息
                }
            })
            .catch(e=>{
                console.log(e)
                error && error(e)
            })
    }

    /**
     *  POST 請(qǐng)求如庭,經(jīng)測(cè)試用FormData傳遞數(shù)據(jù)也可以
     */
    static post(url, params, success, fail, error){
        console.log(url,params)
        fetch(url,{
            method: 'POST',
            headers:{
                'Accept': 'application/json',
                //媒體格式類型key/value格式
                'Content-Type': 'application/x-www-form-urlencoded',
            },
            body: JSON.stringify(params)
        }) .then(response=>response.json())//把response轉(zhuǎn)為json
            .then(responseJson=> { // 拿到上面的轉(zhuǎn)好的json
                console.log(responseJson) // 打印返回結(jié)果
                if (responseJson.code == 200){ // 200為請(qǐng)求成功
                    success && success(responseJson.data)
                }else {
                    fail && fail(responseJson.msg)//可以處理返回的錯(cuò)誤信息
                }
            })
            .catch(e=>{
                console.log(e)
                error && error(error)
            })
    }
    /**
     *  @images uri數(shù)組
     *  @param  FormData格式,沒有參數(shù)的話傳null
     */
    static uploadFile(url,images, params, success, fail, error){
        console.log(url,images)
        let formData = new FormData();
        if (params){
            formData = params;
        }
        for(var i = 0;i<images.length;i++){
            var uri = images[I]
            var date = new Date()
            var name = date.getTime() + '.png'//用時(shí)間戳保證名字的唯一性
            let file = {uri: uri, type: 'multipart/form-data', name: name}
            formData.append('file', file)
        }
        console.log(url,formData)
        fetch(url,{
            method: 'POST',
            headers:{
                'Accept': 'application/json',
                //媒體格式類型key/value格式
                'Content-Type':'multipart/form-data',
                customerId: customerId,
                appId: appId
            },
            body: formData
        }) .then(response=>response.json())//把response轉(zhuǎn)為json
            .then(responseJson=> { // 拿到上面的轉(zhuǎn)好的json
                console.log(responseJson) // 打印返回結(jié)果
                if (responseJson.code == 200){ // 200為請(qǐng)求成功
                    success && success(responseJson.data)
                }else {
                    fail && fail()//可以處理返回的錯(cuò)誤信息
                }
            })
            .catch(e=>{
                console.log(e)
                error && error(error)
            })
    }
}
  • NetAddr.js
var host = 'http://192.168.0.70:8080'

var NetAddr = {
    // 個(gè)人信息
    customerInfo: host + '/Shop/CustomerInfo',
    // 我的訂單列表
    myOrderList: host + '/Shop/MyOrderList',
    // 上傳圖片
    upLoadImage: host + '/Resource/UploadImage'
}

module.exports = NetAddr
  • Connect.js
import NetUtils from './NetUtils'
import NetAddr from './NetAddr'

export default class Connect{
    /**
     *  個(gè)人信息接口
     */
    static getCustomerInfo(success){
        NetUtils.get(NetAddr.customerInfo, null,response=>{
            success && success(response)
        })
    }

    /**
     *  我的訂單列表
     */
    static  postMyOrderList(params, success){
        NetUtils.post(NetAddr.myOrderList, params, response=>{
            success && success(response)
        })
    }

   /**
    *  上傳圖片
    */
    static uploadImageFile(images, params, success){
        NetUtils.uploadFile(NetAddr.upLoadImage, images, params, response=>{
            success && success(response)
        })
     }
}

4、使用

//引入Connect
import Connect from '../../public/net/Connect'

//get請(qǐng)求撼港,無參數(shù)
 getCustomerInfo() {
     Connect.getCustomerInfo(response=>{
          console.log(response)
      })
  }
 //post請(qǐng)求坪它,參數(shù)為FormData形式
 postMyOrderList() {
     let params = new FormData()
     params.append('pageIndex',1)
     params.append('status',0)
     Connect.postMyOrderList(params,response=>{
          console.log(response)
     })
      //參數(shù)json形式
      //Connect.postMyOrderList({'pageIndex': 1, 'status': 0},response=>{
      //    console.log(response)
      //})
    }
 //圖片上傳,photos為圖片地址數(shù)組
uploadImage() {
   Connect.uploadImageFile(photos,null);
}

請(qǐng)求結(jié)果展示

image.png

5帝牡、擴(kuò)展

fetch網(wǎng)絡(luò)請(qǐng)求是沒有超時(shí)處理的往毡,如果需要加上timeout,請(qǐng)參考
讓fetch也可以timeout
[React Native 網(wǎng)絡(luò)請(qǐng)求封裝:使用Promise封裝fetch請(qǐng)求]

6靶溜、結(jié)束語

至此網(wǎng)絡(luò)請(qǐng)求封裝與使用都完成了开瞭,有什么問題歡迎留言探討,如果對(duì)你有幫助或者你喜歡的話罩息,給個(gè)贊吧??嗤详!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市瓷炮,隨后出現(xiàn)的幾起案子葱色,更是在濱河造成了極大的恐慌,老刑警劉巖娘香,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件苍狰,死亡現(xiàn)場(chǎng)離奇詭異办龄,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)舞痰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門土榴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人响牛,你說我怎么就攤上這事玷禽。” “怎么了呀打?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵矢赁,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我贬丛,道長(zhǎng)撩银,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任豺憔,我火速辦了婚禮,結(jié)果婚禮上恭应,老公的妹妹穿的比我還像新娘。我一直安慰自己昼榛,他們只是感情好境肾,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布奥喻。 她就那樣靜靜地躺著,像睡著了一般非迹。 火紅的嫁衣襯著肌膚如雪环鲤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天憎兽,我揣著相機(jī)與錄音楔绞,去河邊找鬼。 笑死唇兑,一個(gè)胖子當(dāng)著我的面吹牛酒朵,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播扎附,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼蔫耽,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起匙铡,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤图甜,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后鳖眼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體黑毅,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年钦讳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了矿瘦。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡愿卒,死狀恐怖缚去,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情琼开,我是刑警寧澤易结,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站柜候,受9級(jí)特大地震影響搞动,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜渣刷,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一滋尉、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧飞主,春花似錦、人聲如沸高诺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)虱而。三九已至筏餐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間牡拇,已是汗流浹背魁瞪。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留惠呼,地道東北人导俘。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像剔蹋,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子泣崩,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容