js中es6新增请求方法fetch的封装

typescript 复制代码
function formtor(data) {
    let dataStr = ''
    Object.keys(data).forEach(key => {
       dataStr += key + '=' + data[key] + '&'
    })
    if (dataStr !== '') {
       dataStr = dataStr.substring(0, dataStr.length - 1)
    }
    return dataStr
}

async function ajax(url = '', type = 'GET', data = {}) {
    if (type === "GET") {
       const dataStr = formtor(data)
       url += url + '?' + dataStr
    }
    let requestConfig = {
       method: type,
       headers: {
          "Content-type": "application/x-www-form-urlencoded;charset=UTF-8"
       }

    }
    if (type === "POST") {
       // requestConfig.body = formtor(data)
       //拦截对象,为对象增加新的属性
       //在es6中,我们不推荐直接为一个对象增加新属性的时候使用读取方式
       Object.defineProperties(requestConfig, "body", {
          value: formtor(data)
       })
    }
    const response = await fetch(url, requestConfig)
    const responseJSON = await response.json()
    return responseJSON
}
相关推荐
五点六六六18 小时前
跨端RN 与 浏览器Web 的 长渲染性能 差异 与 底层 揭秘
前端·react native·webgl
咬人喵喵18 小时前
18 类年终总结核心 SVG 交互方案拆解
前端·css·编辑器·交互·svg
不想秃头的程序员19 小时前
JS继承方式详解
前端·面试
刺客-Andy19 小时前
JS中级面试题 50道及答案
开发语言·javascript·ecmascript
Mapmost19 小时前
【高斯泼溅】从“看清”到“看懂”,3DGS语义化让数字孪生“会说话”
前端
指尖跳动的光19 小时前
防止前端页面重复请求
前端·javascript
luquinn19 小时前
用canvas切图展示及标记在原图片中的位置
开发语言·前端·javascript
巧克力芋泥包19 小时前
前端vue3调取阿里的oss存储
前端
AAA阿giao19 小时前
React Hooks 详解:从 useState 到 useEffect,彻底掌握函数组件的“灵魂”
前端·javascript·react.js
RedHeartWWW19 小时前
Next.js Middleware 极简教程
前端