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文件,接收两个参数,第一个是地址,第二个是请求参数。


使用方法
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 前端开发面试知识点大纲: HTML&CSS: 对Web标准的理解、浏览器内核差异、兼容性、hack、CSS基本功:...
    秀才JaneBook阅读 2,570评论 0 25
  • 本文旨在加深对前端知识点的理解,资料来源于网络,由本人(博客:http://segmentfault.com/u/...
    风起云帆阅读 336评论 0 0
  • 声明:这些题目是在某个前端群看到的,在这分享给大家,如有侵权,请私信。 1.一些开放性题目 position的值,...
    一岁一枯荣_阅读 6,540评论 0 33
  • 前言 本文有配套视频,可以酌情观看。 文中内容因各人理解不同,可能会有所偏差,欢迎朋友们联系我。 文中所有内容仅供...
    珍此良辰阅读 1,540评论 13 7