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
}
相关推荐
前端小巷子2 分钟前
跨标签页通信(二):Service Worker
前端·面试·浏览器
默默地离开2 分钟前
文档流之css布局块(盒子模型)
前端·css
派大星jason3 分钟前
flutter 上架国内应用市场
前端
笔尖执着3 分钟前
AntV/G6: 实现产业图谱
前端
用泥种荷花4 分钟前
前端也要会“编码”知识,leader再也不用担心乱码问题了!!!
前端
不一样的少年_4 分钟前
浏览器插件(crx)实现多标签页数据同步机制
前端·浏览器
鑫玉5 分钟前
NodeJS-fs文件系统模块&path路径模块
前端
comelong5 分钟前
还有人不知道IntersectionObserver也可以实现懒加载吗
前端·javascript·面试
玲小珑9 分钟前
Auto.js 入门指南(十五)脚本加密与安全防护
android·前端
设计师也学前端9 分钟前
SVG数据可视化组件基础教程6:翻牌倒计时
前端·svg