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
}
相关推荐
b1gbrother13 分钟前
让你的Claude Code变得更聪明
前端·程序员
国家不保护废物22 分钟前
多模态模型数据传输的秘密武器:html5对象Blob深度解析
前端·面试·html
用户25191624271122 分钟前
Canvas之概述,画布与画笔
前端·javascript·canvas
南方kenny22 分钟前
前端小知识:搞懂 BFC块级格式化上下文,告别面试“拦路虎”!
前端·css·面试
邵洛23 分钟前
前端导出excel表格并修改导出表格样式
前端
风舞23 分钟前
JavaScript 核心概念及代码示例的梳理
前端
学长学姐我该怎么办25 分钟前
从零开始学前端html篇2
前端·html
尘世中一位迷途小书童26 分钟前
从零实现 Canvas 图形拖拽:让你的网页动起来!
前端
mrsk27 分钟前
JavaScript之变量的解构赋值全面解析(●'◡'●)
前端·javascript·面试
归于尽27 分钟前
回调函数在Node.js中是怎么执行的?
前端·javascript·node.js