请求拦截 XMLHttpRequest和fetch

// 拦截请求
const XHR = window.XMLHttpRequest

window.XMLHttpRequest = class XMLHttpRequest extends XHR {
  method = 'GET'

  constructor() {
    super()
    const { open } = this
    this.open = (
      method: string,
      url: string | URL,
      async?: boolean,
      username?: string | null,
      password?: string | null,
    ) => {
      this.method = method || 'GET'
      window.dispatchEvent(
        new CustomEvent('ajax_interceptor_start', {
          detail: {
            methods: this.method,
            url,
          },
        }),
      )
      open.apply(this, [method, url, async !== undefined ? async : true, username, password])
    }
    this.addEventListener(
      'readystatechange',
      () => {
        if (this.readyState === 4) {
          window.dispatchEvent(
            new CustomEvent('ajax_interceptor', {
              detail: {
                method: this.method,
                status: this.status,
                url: this.responseURL,
                response: this.response,
              },
            }),
          )
        }
      },
      false,
    )
  }
}

if (window.fetch) {
  const Fetch = window.fetch
  window.fetch = (url, init) => {
    window.dispatchEvent(
      new CustomEvent('ajax_interceptor_start', {
        detail: {
          methods: init?.method || 'GET',
          url,
        },
      }),
    )
    return Fetch(url, init).then(async response => {
      const data = await response.clone().text()
      window.dispatchEvent(
        new CustomEvent('ajax_interceptor', {
          detail: {
            methods: init?.method || 'GET',
            status: response.status,
            url: response.url,
            response: data,
          },
        }),
      )
      return response
    })
  }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值