Axios를 두 번 캡슐화하고 매개변수(코드)를 기반으로 다중 요청과 다중 차단을 구현하는 방법
이 기사의 내용은 axios를 다시 캡슐화하고 매개변수를 기반으로 다중 요청 및 다중 가로채기(코드)를 구현하는 방법에 대한 것입니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
1. 새로운 axiosTool.js 파일을 생성하고 요청 차단 및 처리를 위한 로직을 설정하세요
import Vue from 'vue' import axios from 'axios' //取消请求 let CancelToken = axios.CancelToken //设置默认请求头,如果不需要可以取消这一步 axios.defaults.headers = { 'X-Requested-With': 'XMLHttpRequest' } // 请求超时的时间限制 axios.defaults.timeout = 20000 // 开始设置请求 发起的拦截处理 // config 代表发起请求的参数的实体 axios.interceptors.request.use(config => { // 得到参数中的 requestName 字段,用于决定下次发起请求,取消对应的 相同字段的请求 // 如果没有 requestName 就默认添加一个 不同的时间戳 let requestName if(config.method === 'post'){ if(config.data && config.data.requestName){ requestName = config.data.requestName }else{ requestName = new Date().getTime() } }else{ if(config.params && config.params.requestName){ requestName = config.params.requestName }else{ requestName = new Date().getTime() } } // 判断,如果这里拿到的参数中的 requestName 在上一次请求中已经存在,就取消上一次的请求 if (requestName) { if (axios[requestName] && axios[requestName].cancel) { axios[requestName].cancel() } config.cancelToken = new CancelToken(c => { axios[requestName] = {} axios[requestName].cancel = c }) } return config }, error => { return Promise.reject(error) }) // 请求到结果的拦截处理 axios.interceptors.response.use(config => { // 返回请求正确的结果 return config }, error => { // 错误的请求结果处理,这里的代码根据后台的状态码来决定错误的输出信息 if (error && error.response) { switch (error.response.status) { case 400: error.message = '错误请求' break case 401: error.message = '未授权,请重新登录' break case 403: error.message = '拒绝访问' break case 404: error.message = '请求错误,未找到该资源' break case 405: error.message = '请求方法未允许' break case 408: error.message = '请求超时' break case 500: error.message = '服务器端出错' break case 501: error.message = '网络未实现' break case 502: error.message = '网络错误' break case 503: error.message = '服务不可用' break case 504: error.message = '网络超时' break case 505: error.message = 'http版本不支持该请求' break default: error.message = `连接错误${error.response.status}` } } else { error.message = "连接到服务器失败" } return Promise.reject(error.message) }) // 将axios 的 post 方法,绑定到 vue 实例上面的 $post Vue.prototype.$post = function (url, params) { return new Promise((resolve, reject) => { axios.post(url, params) .then(res => { resolve(res) }).catch(err => { reject(err) }) }) } // 将axios 的 get 方法,绑定到 vue 实例上面的 $get Vue.prototype.$get = function (url, params) { return new Promise((resolve, reject) => { axios.get(url, { params: params }).then(res => { resolve(res) // 返回请求成功的数据 data }).catch(err => { reject(err) }) }) } // 请求示例 // requestName 为多余的参数 作为请求的标识,下次发起相同的请求,就会自动取消上一次还没有结束的请求 // 比如正常的请求参数只有一个 name: '123',但是这里我们需要额外再加上一个 requestName /** this.$post(url, { name: '123', requestName: 'post_1' }) .then(res => { console.log(`请求成功:${res}`) }) */ export default axios
2. 파일을 main.js
import { axios } from './static/js/axiosTool'
에 추가하세요. 으아아아
위 내용은 Axios를 두 번 캡슐화하고 매개변수(코드)를 기반으로 다중 요청과 다중 차단을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











HTML의 테이블 테두리 안내. 여기에서는 HTML의 테이블 테두리 예제를 사용하여 테이블 테두리를 정의하는 여러 가지 방법을 논의합니다.

HTML 여백-왼쪽 안내. 여기에서는 HTML margin-left에 대한 간략한 개요와 코드 구현과 함께 예제를 논의합니다.

HTML의 Nested Table에 대한 안내입니다. 여기에서는 각 예와 함께 테이블 내에 테이블을 만드는 방법을 설명합니다.

HTML 테이블 레이아웃 안내. 여기에서는 HTML 테이블 레이아웃의 값에 대해 예제 및 출력 n 세부 사항과 함께 논의합니다.

HTML 입력 자리 표시자 안내. 여기서는 코드 및 출력과 함께 HTML 입력 자리 표시자의 예를 논의합니다.

HTML 순서 목록에 대한 안내입니다. 여기서는 HTML Ordered 목록 및 유형에 대한 소개와 각각의 예에 대해서도 설명합니다.

HTML에서 텍스트 이동 안내. 여기서는 Marquee 태그가 구문과 함께 작동하는 방식과 구현할 예제에 대해 소개합니다.

HTML onclick 버튼에 대한 안내입니다. 여기에서는 각각의 소개, 작업, 예제 및 다양한 이벤트의 onclick 이벤트에 대해 설명합니다.
