React Native 之fetch常用請求封裝

封裝的文件為http.js,import的storage是asyncStorage的setitem,getitem的封裝。

let queryString = require('query-string');
import Storage from './storage'
import {
    Platform
} from 'react-native'

const os = Platform.OS;

function checkStatus(response) {
    if (response.status >= 200 && response.status < 300) {
        return response
    } else {
        let error = new Error(response.statusText)
        error.response = response
        throw error
    }
}
function parseJSON(response) {
    return response.json()
}
async function get(url, params) {
    if (params) {
        url += `?${queryString.stringify(params)}`
    }
    try {
        let headers = new Headers();
        let Access_Token = await Storage.getItem('Access_Token');
        if (Access_Token) {
            headers.append('Access_Token', Access_Token);
            headers.append('UserAgent',os);
        }
        console.log(headers,url)
        return fetch(url, {
            headers: headers
        })
            .then(checkStatus)
            .then(parseJSON)
    } catch (e) {
        throw new Error('get error')
    }

}

async function post(url, body) {
    let Access_Token = await Storage.getItem('Access_Token');
    let fetchOptions = {
        method: 'POST',
        headers: {
            'Accept': 'application/json',
            'Content-Type': 'application/json',
            'Access_Token': Access_Token ? Access_Token : '',
            'UserAgent':os
        },
        body: JSON.stringify(body)
    }
    return fetch(url, fetchOptions)
        .then(checkStatus)
        .then(parseJSON)
}

async function del(url, params) {
    if (params) {
        url += `?${queryString.stringify(params)}`
    }
    let Access_Token = await Storage.getItem('Access_Token');
    let fetchOptions = {
        method: 'DELETE',
        headers:{
            'Accept': 'application/json',
            'Content-Type': 'application/json',
            'Access_Token': Access_Token ? Access_Token : '',
            'UserAgent':os
        }
    }
    return fetch(url, fetchOptions)
        .then(checkStatus)
        .then(parseJSON)
}

async function update(url, body) {
    let Access_Token = await Storage.getItem('Access_Token');
    let fetchOptions = {
        method: 'PUT',
        headers: {
            'Accept': 'application/json',
            'Content-Type': 'application/json',
            'Access_Token': Access_Token ? Access_Token : '',
            'UserAgent':os
        },
        body: JSON.stringify(body)
    }
    return fetch(url, fetchOptions)
        .then(checkStatus)
        .then(parseJSON)
}

async function uploadFile(url, params, fileUrl,fileName) {
    let Access_Token = await Storage.getItem('Access_Token');
    let data = new FormData();
    data.append('file', {
        uri: fileUrl,
        name: fileName,
        type: 'image/jpeg'
    });

    Object.keys(params).forEach((key)=> {
        if (params[key] instanceof Date) {
            data.append(key, value.toISOString())
        } else {
            data.append(key, String(params[key]))
        }
    });
    const fetchOptions = {
        method: 'POST',
        headers: {
            'Accept': 'application/json',
            'Access_Token': Access_Token ? Access_Token : '',
            'UserAgent':os
        },
        body: data
    };
    return fetch(url, fetchOptions)
        .then(checkStatus)
        .then(parseJSON)
}
export default {
    get,
    post,
    del,
    update,
    uploadFile
}

在需要用到的地方引入http文件,接收兩個參數(shù),第一個是地址,第二個是請求參數(shù)。


使用方法
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,533評論 19 139
  • 前端開發(fā)面試知識點(diǎn)大綱: HTML&CSS: 對Web標(biāo)準(zhǔn)的理解、瀏覽器內(nèi)核差異、兼容性、hack、CSS基本功:...
    秀才JaneBook閱讀 2,762評論 0 25
  • 本文旨在加深對前端知識點(diǎn)的理解,資料來源于網(wǎng)絡(luò),由本人(博客:http://segmentfault.com/u/...
    風(fēng)起云帆閱讀 355評論 0 0
  • 聲明:這些題目是在某個前端群看到的,在這分享給大家,如有侵權(quán),請私信。 1.一些開放性題目 position的值,...
    一歲一枯榮_閱讀 6,580評論 0 33
  • 前言 本文有配套視頻,可以酌情觀看。 文中內(nèi)容因各人理解不同,可能會有所偏差,歡迎朋友們聯(lián)系我。 文中所有內(nèi)容僅供...
    珍此良辰閱讀 1,674評論 13 7

友情鏈接更多精彩內(nèi)容