【随机笔记】- http请求之fetch封装

【随机笔记】- http请求之fetch封装

  • 技术点:Fetch,URLSearchParams,ES7 async/await
import fetch from 'isomorphic-fetch'
import URLSearchParams from 'url-search-params'

/**
 * 序列化参数 (get)
 * @param {any} obj
 * @returns
 */
function serialiseObject (obj) {
  const prefix = '?'

  if (obj && Object.keys(obj).length) {
    return prefix + Object.keys(obj).map(key =>
      `${key}=${encodeURIComponent(obj[key])}`
    ).join('&')
  }

  return ''
}

/**
 * 获取参数 (post)
 * @param {any} payload
 * @returns
 */
function getParams (payload) {
  let datas = new URLSearchParams()
  for (const prop in payload) {
    let val = typeof payload[prop] === 'object'
      ? JSON.stringify(payload[prop])
      : payload[prop]
    datas.set(prop, val)
  }
  // console.log(datas.toString())
  return datas
}

/**
 * 检查状态码
 * @param {any} response
 * @returns
 */
function checkStatus (response) {
  if (response.status >= 200 && response.status < 300) {
    return response
  } else {
    var error = new Error(response.statusText)
    error.response = response
    throw error
  }
}

/**
 * 返回数据
 * @param {any} response
 * @returns
 */
function parseJSON (response) {
  return response.json()
}

const http = {
  /**
   * get 请求方式
   * @param {any} path
   * @param {any} params
   * @returns
   */
  async get (path, params) {
    let url = `${path}${serialiseObject(params)}`
    try {
      let request = await fetch(url)
      let checked = await checkStatus(request)
      let json = await parseJSON(checked)

      return json
    } catch (error) {
      throw new Error(error)
    }
  },

  /**
   * post请求方式
   * @param {any} url
   * @param {any} payload
   * @returns
   */
  async post (url, payload) {
    // let options = {
    //   method: 'POST',
    //   body: qs.stringify(body),
    //   headers: {
    //     'Content-Type': 'application/x-www-form-urlencoded'
    //   }
    // }
    let options = {
      method: 'POST',
      body: getParams(payload)
    }
    try {
      let request = await fetch(url, options)
      let checked = await checkStatus(request)
      let json = await parseJSON(checked)

      return json
    } catch (error) {
      throw new Error(error)
    }
  }

}

export default http复制代码
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值