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
}
相关推荐
2301_815279526 分钟前
实战分享实现 C++ 管理类单例模式:特点与最佳实践
javascript·c++·单例模式
原则猫15 分钟前
await 到底在等待什么
前端
西洼工作室24 分钟前
fetch+ReadableStream实现SSE推送实时踢人下线
前端·python·全栈
2401_8784545324 分钟前
js的复习(一)
开发语言·javascript·ecmascript
农夫山泉不太甜30 分钟前
Nuxt 4 完全指南:从入门到精通
前端
Momo__32 分钟前
Vue 3.4+ 被低估的 3 个 API,让你的代码更优雅
前端·vue.js
dishugj35 分钟前
HANA数据库常用命令总结
java·前端·数据库
clove39 分钟前
JavaScript 提升(Hoisting)与声明优先级:一篇文章说透
前端
七牛开发者43 分钟前
不写框架、不用 npm,我用 AI Coding 做了一个家庭记忆站
前端·人工智能·npm