如何使用fetch进行通用API调用功能

时间:2019-07-06 09:45:12

标签: reactjs typescript fetch-api

我正在尝试创建通用功能,该功能可以处理来自任何地方的所有API调用

我正在使用react“:” ^ 16.8.6“并提取用于进行api调用

到目前为止,我已经确定要做什么 是

Helper.js

export function ApiHelper(url, data = {}, method = 'POST') {
    let bearer = 'Bearer ' + localStorage.getItem('user_token');
    var promise = fetch(url, {
        method: method,
        withCredentials: true,
        // credentials: 'include',
        headers: {
            'Authorization': bearer,
            'X-FP-API-KEY': 'chaptoken', 
            'Content-Type': 'application/json'
        }
    })
    .then(res => res.json())
    .then(
        (result) => {
            console.log(result);
        },
        (error) => {
            error = error;
        }
    )
}

export function AnyOtherHelper() {
    return 'i am from helper function';
}

这是我调用此函数的地方

componentDidMount() {
    let url = `http://localhost/project/api/getdata`;
    let op = ApiHelper(url);
}

当我在then中获得结果时,我得到了适当的结果,但是我想返回该响应,我该如何做这部分却困扰着我 即使我尝试将结果存储在全局变量中,也无法正常工作。 另外,我只能在答应解决后才返回响应。

1 个答案:

答案 0 :(得分:4)

您正在通过助手函数进行异步调用,这意味着您将必须像这样从助手函数返回诺言-

export function ApiHelper(url, data = {}, method = 'POST') {
    let bearer = 'Bearer ' + localStorage.getItem('user_token');
    return fetch(url, {  // Return promise
        method: method,
        withCredentials: true,
        // credentials: 'include',
        headers: {
            'Authorization': bearer,
            'X-FP-API-KEY': 'chaptoken',
            'Content-Type': 'application/json'
        }
    })
        .then(res => res.json())
        .then((result) => {
            console.log(result);
            return result;
        }, (error) => {
            error = error;
        })
}

用法

componentDidMount() {
    let url = `http://localhost/project/api/getdata`;
    ApiHelper(url)
    .then(resposnse => {
        console.log(resposnse);
    });
}