fetch-封装

简介: 上篇文章写了fetch基础配置这篇文章写写 在项目中的简要封装 其实vue和react的封装都差不多

1.前言


上篇文章写了fetch基础配置

这篇文章写写 在项目中的简要封装 其实vuereact的封装都差不多


2. 基础 api封装


src/api/fetch.js


//get请求封装
const fetchGet = function(url, params) {
    let list = [];
    for (let key in params) {
        let str = `${key}=${params[key]}`
        list.push(str);
    }
    const data = list.join('&');
    let allUrl = `${url}?${data}`;
    // debugger
    return fetch(allUrl).then(res => {
        return res.json();
    }).catch(err => {
        console.log(err);
    });
};
// post请求封装
const fetchPost = function(url, params) {
    let formData = new FormData();
    for (let key in params) {
        formData.append(key, params[key])
    };
    return fetch(url, {
        body: formData,
        method: 'POST'
    }).then(res => {
        return res.json();
    }).catch(err => {
        console.log(err);
    })
};
// 这个其实写不写都不行
const fetchAll = function(url, params, method='GET') {
    if (method === 'GET' || method === 'get') {
        return fetchGet(url, params);
    } 
    return fetchPost(url, params);
}
export default {
    fetchGet,
    fetchPost,
    fetchAll
}

都比较简单也没什么需要说的


3. 使用



import myFetch from '@/api/fetch.js';
 onMounted(()=>{
               myFetch.fetchGet("https://yzs.example.org/v1/getData",{
                   id:"yzs123"
               }).then(res => {
                    console.log(res);
                }).catch(err => {
                    console.log(err);
                })
})


下面的和上面的不相干 是另外一种封装方式


4.  整个的 fetch  环境配置



export default async(url = '', data = {}, type = 'GET', method = 'fetch') => {
    const baseUrl = "http://yzs.com"
    type = type.toUpperCase();
    url = baseUrl + url;
    if (type == 'GET') {
        let dataStr = ''; //数据拼接字符串
        Object.keys(data).forEach(key => {
            dataStr += key + '=' + data[key] + '&';
        })
        if (dataStr !== '') {
            dataStr = dataStr.substr(0, dataStr.lastIndexOf('&'));
            url = url + '?' + dataStr;
        }
    }
    if (window.fetch && method == 'fetch') {
        let requestConfig = {
            credentials: 'include',
            method: type,
            headers: {
                'Accept': 'application/json',
                'Content-Type': 'application/json'
            },
            mode: "cors",
            cache: "force-cache"
        }
        if (type == 'POST') {
            Object.defineProperty(requestConfig, 'body', {
                value: JSON.stringify(data)
            })
        }
        try {
            const response = await fetch(url, requestConfig);
            const responseJson = await response.json();
            return responseJson
        } catch (error) {
            throw new Error(error)
        }
    } else {
        return new Promise((resolve, reject) => {
            let requestObj;
            if (window.XMLHttpRequest) {
                requestObj = new XMLHttpRequest();
            } else {
                requestObj = new ActiveXObject;
            }
            let sendData = '';
            if (type == 'POST') {
                sendData = JSON.stringify(data);
            }
            requestObj.open(type, url, true);
            requestObj.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
            requestObj.send(sendData);
            requestObj.onreadystatechange = () => {
                if (requestObj.readyState == 4) {
                    if (requestObj.status == 200) {
                        let obj = requestObj.response
                        if (typeof obj !== 'object') {
                            obj = JSON.parse(obj);
                        }
                        resolve(obj)
                    } else {
                        reject(requestObj)
                    }
                }
            }
        })
    }
}



5. api配置


api/getData.js


/**
 * 获取导航菜单
 */
export const getHomeNavData = () => fetch('/v1/getData', {
    userId: 'yzs123456'
})
/**
 * 获取首页列表
 */
export const queryList= ( kw, type) => fetch('/v2/query',{
    kw,
    type
}, 'POST')



6. 使用



import {getHomeNavData} from 'src/service/getData'
        getHomeNavData (this.userId).then(res => {
                console.log("res",res)
            })
       queryList("郑州加油","1",).then(res => {
                    console.log("REs-----------:",res)
            })




相关文章
|
18天前
|
JSON 数据格式
|
18天前
|
XML JSON 前端开发
你知道 XHR 和 Fetch 的区别吗?
你知道 XHR 和 Fetch 的区别吗?
306 1
|
7月前
|
JSON 前端开发 JavaScript
ajax和axios、fetch的区别
ajax和axios、fetch的区别
|
JSON 数据处理 数据格式
🌮微卷不亏,4 分钟优化 Fetch 函数写法~
上一篇介绍了啥叫“微卷不亏”,今天继续简单微卷一些小知识点:本篇带来《如何优化 Fetch 函数写法》,轻松拿下~
|
移动开发
h5 fetch的 原理 使用 学习总结
h5 fetch的 原理 使用 学习总结
|
JSON 前端开发 数据格式
Ajax&Fetch学习笔记 08、Fetch
Ajax&Fetch学习笔记 08、Fetch
Ajax&Fetch学习笔记 08、Fetch
|
XML JSON 前端开发
你知道Ajax、Fetch、Axios三者的区别吗?
前言 做前端开发的小伙伴一定离不开“请求”两个字,这是我们与后端交互的最重要的途径!在前几年面试的时候,面试官很喜欢问的一个问题就是让面试者手撕代码实现 Ajax,我相信很多小伙伴一定遇到过。直至今日,又出现了许多关于请求的新名词,今天就来理一理这些新名词的区别。 这些名词的共同点:都用于发送网络请求。
265 0
你知道Ajax、Fetch、Axios三者的区别吗?
|
Web App开发 JSON API
使用装饰器模式强大你的 fetch
使用装饰器模式强大你的 fetch
110 0
|
前端开发
前后端交互的五种方式-fetch-xhr区别
简单的总结下前端的请求方式
190 0

热门文章

最新文章