当前位置: 首页 > news >正文

全国网页设计大赛品牌榜中榜长沙优化排名

全国网页设计大赛品牌榜中榜,长沙优化排名,wordpress摘要设置,教学网站前台er图token配置、中英文配置、对所有接口统一设置防抖、对所有post接口统一设置节流 废话少说直接上代码 request.js import axios from axios // 使用element-ui Message做消息提醒 import { ElMessage } from element-plus//这是为了防止刁民反复切换页面,切换页面…

token配置、中英文配置、对所有接口统一设置防抖、对所有post接口统一设置节流 

废话少说直接上代码

request.js 

import axios from 'axios'
// 使用element-ui Message做消息提醒
import { ElMessage } from 'element-plus'//这是为了防止刁民反复切换页面,切换页面时对还在请求中的接口进行中断
// const CancelToken = axios.CancelToken;
// import pinia from '../store'
// import { useNet } from '../store/net'
// const net = useNet(pinia)
import routes from '../router/index.js'//中英文,不使用注释掉,$t('xxx.xxx.xxx')改成你想要的提示
import { translate as $t } from "../language/index"//创建axios
const instance = axios.create({baseURL: process.env.BASE_API,timeout: 10000
})
//节流
let lastTime = new Date().getTime()
//防抖
const debounceTokenCancel = new Map()//请求前拦截
instance.interceptors.request.use(config => {const token = localStorage.getItem('token');config.headers = {//配置token'Content-Type': 'application/json','T-Authorization': token,//中英文标识,判断当前中英文'Accept-Language': localStorage.getItem("language") == null ? 'zh-CN' : localStorage.getItem("language") == 'zh' ? 'zh-CN' : 'en-US'}//切换页面强行中断请求// config.cancelToken = new CancelToken(c => {//     net.cancel = c// })//请求接口进行标识const tokenKey = `${config.method}-${config.url}`//存在可以防抖的情况,取消请求const cancel = debounceTokenCancel.get(tokenKey)if (cancel) {cancel()}return new Promise(resolve => {let timerif (config.method == 'get') {//放行get请求resolve(config)} else if (config.method == 'post') {//开始节流const nowTime = new Date().getTime()if (nowTime - lastTime < 1000) {ElMessage.error({showClose: true,message: $t('text.Common.l25'),type: 'error',})return Promise.reject(new Error('节流处理中,稍后再试'))} else {//开始防抖lastTime = nowTimetimer = setTimeout(() => {clearTimeout(timer)resolve(config)}, 10)//发生重复请求,进行取消debounceTokenCancel.set(tokenKey, () => {clearTimeout(timer)resolve(new Error('取消请求'))})}}})
}, error => {console.log(error)return Promise.reject(error)
})// let showError = false; // 新增一个变量来控制是否已经显示错误消息
// let timerError = null; // 新增一个计时器//响应后拦截
instance.interceptors.response.use(response => {if (response.data.code === 0) {return response.data.data} else {//跳转到登陆页面if (response.data.code == 402 || response.data.code == 401) {routes.push({ path: '/login' })}ElMessage.error({showClose: true,message: response.data.msg,type: 'error',})// if (!showError) { // 如果错误消息未显示//     ElMessage.error({//         showClose: true,//         message: response.data.msg,//         type: 'error',//     })//     showError = true; // 设置为已显示//     // 设置一个计时器,在一段时间后重置 showError//     timerError = setTimeout(() => {//         showError = false;//         clearTimeout(timerError);//     }, 1000); // 1000毫秒后重置// }}//return response
}, error => {//其它异常处理if (JSON.stringify(error).includes('500')) {ElMessage.error({showClose: true,message: $t('text.Common.l26'),type: 'error',})}return Promise.reject(error)
})export default instance

api.js:

import request from "./request.js";const baseUrl = '/api'//post
export function login(params) {return request({url: baseUrl + "/opsli-boot/system/login",method: "post",data: params});
}//get
export function findListByTypeCode(params) {return request({url: baseUrl + "/a123/b456",method: "get",});
}

使用: 

        
import { getKey } from '../../http/api'getKey().then(res => {//在request进行了拦截,如果请求没成功是不返回的,判断成功时一定要判断res !== undefinedif (res !== undefined) {console.log(res)}}).catch()

 

 

http://www.mmbaike.com/news/106502.html

相关文章:

  • app开发网站建设游戏广告投放平台
  • 腾讯云电商网站建设企业网络推广的方式有哪些
  • 廊坊论坛网站建设sem与seo
  • 360网站seo怎么做seo关键词排名软件
  • 外发加工网站源码下载2023年最新新闻摘抄
  • 网站组件企业网站建设目标
  • wordpress 搭建seo什么意思简单来说
  • 做网站有生意吗天津网站seo设计
  • 项目管理资格证书重庆网站关键词排名优化
  • 怎样自己弄一个网站推广普通话手抄报内容简短
  • css 网站 实例石家庄网站建设就找
  • 网页作业怎么做一个网站怎么搜索网站
  • 南阳做网站seo的今晚日本比分预测
  • 头条网站怎么做的百度广告联盟平台
  • 建立一个属于自己的网站2021年热门关键词
  • 响应式网站模板分享龙岗网站设计
  • 湖北孝感展示型网站建设价格快速申请免费个人网站
  • 网站建站图片热门网站排名
  • 学网站开发 优帮云网络销售工作靠谱吗
  • 知道内容怎样让别人做网站大型网站建设平台
  • 做个门户网站多少钱马鞍山网站seo
  • 如何做网站么seo网站优化工具
  • 做网站好还是小程序好百度seo怎么查排名
  • 山东德州网站建设哪家最专业苹果cms永久免费建站程序
  • 建设网站会员登陆企业网站多少钱一年
  • 广西建设学院官方网站制作链接的app的软件
  • 网站赌博做员工犯法吗网络营销与电子商务的区别
  • 国外自建站好做吗网络营销服务企业有哪些
  • 建企业版网站多久营销推广的特点是
  • 高端购物网站青岛百度网站排名