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
}
相关推荐
_Kayo_10 分钟前
CSS BFC
前端·css
二哈喇子!1 小时前
Vue3 组合式API
前端·javascript·vue.js
二哈喇子!3 小时前
Vue 组件化开发
前端·javascript·vue.js
chxii3 小时前
2.9 插槽
前端·javascript·vue.js
姑苏洛言4 小时前
扫码点餐小程序产品需求分析与功能梳理
前端·javascript·后端
Freedom风间4 小时前
前端必学-完美组件封装原则
前端·javascript·设计模式
江城开朗的豌豆4 小时前
React表单控制秘籍:受控组件这样玩就对了!
前端·javascript·react.js
一枚前端小能手4 小时前
📋 代码片段管理大师 - 5个让你的代码复用率翻倍的管理技巧
前端·javascript
国家不保护废物4 小时前
Web Worker 多线程魔法:告别卡顿,轻松实现图片压缩!😎
前端·javascript·面试
接着奏乐接着舞。4 小时前
如何在Vue中使用拓扑图功能
前端·javascript·vue.js