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

com都有哪些网站品牌关键词优化哪家便宜

com都有哪些网站,品牌关键词优化哪家便宜,网页制作流程图模板,小的电商网站在单页面应用中通常会对请求进行catch处理,如果用户打开a页面后页面发出了一个请求去获取aaa,但是由于某种原因请求一直在pending。此时用户又进入了b页面,在浏览时a页面的请求失败了,然后页面弹出提示:“数据aaa请求失…

在单页面应用中通常会对请求进行catch处理,如果用户打开a页面后页面发出了一个请求去获取aaa,但是由于某种原因请求一直在pending。此时用户又进入了b页面,在浏览时a页面的请求失败了,然后页面弹出提示:“数据aaa请求失败”。这就很尴尬了。虽然在对于a页面没什么问题,但是对于b页面来说这就是无用的提示。这时就需要在跳转页面时杀掉正在pending的请求了

axios的cancelToken

https://www.kancloud.cn/yunye/axios/234845

使用 cancel token 取消请求
可以使用 CancelToken.source 工厂方法创建 cancel token,像这样:

var CancelToken = axios.CancelToken;
var source = CancelToken.source();axios.get('/user/12345', {cancelToken: source.token
}).catch(function(thrown) {if (axios.isCancel(thrown)) {console.log('Request canceled', thrown.message);} else {// 处理错误}
});// 取消请求(message 参数是可选的)
source.cancel('Operation canceled by the user.');

还可以通过传递一个 executor 函数到 CancelToken 的构造函数来创建 cancel token:

var CancelToken = axios.CancelToken;
var cancel;axios.get('/user/12345', {cancelToken: new CancelToken(function executor(c) {// executor 函数接收一个 cancel 函数作为参数cancel = c;})
});// 取消请求
cancel();

vue路由跳转时cancel请求

定义请求services.js

import axios from 'axios';const url = 'http://localhost:3001';export function AApi() {return axios.get(`${url}/a`);
}export function BApi() {return axios.get(`${url}/b`);
}export function CApi() {return axios.get(`${url}/c`, {cancelToken: null, // 避免被加入cancel队列});
}

定义axios拦截器设置cancelToken

export * from './services';import axios from 'axios';const cancelTokenSources = new Map(); // 定义cancel队列axios.interceptors.request.use(config => { // 请求拦截器中将请求加入cancel队列if (!config.hasOwnProperty('cancelToken')) { // 排除不需要cancel的请求const source = axios.CancelToken.source();cancelTokenSources.set(source.token, source.cancel); // 加入cancel队列config.cancelToken = source.token;}return config;
}, error => Promise.reject(error));axios.interceptors.response.use(res => { // 响应拦截器中从cancel队列中移除if (res.config.cancelToken) {cancelTokenSources.delete(res.config.cancelToken);}return res;
}, error => {if (axios.isCancel(error)) {cancelTokenSources.delete(error.message)}return Promise.reject(error)
});export default cancelTokenSources;

将需要放弃的请求加入cancel队列

定义路由router.js

import Vue from 'vue'
import Router from 'vue-router'
import Home from './views/Home.vue'
import About from './views/About.vue'
import cancelTokenSources from './api';Vue.use(Router);const router = new Router({mode: 'history',base: process.env.BASE_URL,routes: [{path: '/',name: 'home',component: Home},{path: '/about',name: 'about',// route level code-splitting// this generates a separate chunk (about.[hash].js) for this route// which is lazy-loaded when the route is visited.component: About}]
});router.afterEach(() => { // 路由跳转杀请求for (const [cancelToken, cancel] of cancelTokenSources) {cancel(cancelToken); // cancel 正在pending的请求}
});export default router;

路由跳转时对cancel队列进行遍历kill

定义about页面,放出请求

<template><div class="about"><h1>This is an about page</h1></div>
</template><script>import { AApi, BApi, CApi } from '../api';import axios from 'axios';export default {name: 'about',mounted() {AApi().catch(err => {if (axios.isCancel(err)) {console.log('请求被关闭了');} else {console.log('请求出问题了');}});BApi().catch(err => {if (axios.isCancel(err)) {console.log('请求被关闭了');} else {console.log('请求出问题了');}});CApi().catch(err => {if (axios.isCancel(err)) {console.log('请求被关闭了');} else {console.log('请求出问题了');}});}}
</script>

效果图

进入about页面

在这里插入图片描述

跳转至其他页面

image

由于c接口加入了cancelToken: null, 所以不会被杀掉。a和b状态已经变为canceled。
在这里插入图片描述

http://www.hkea.cn/news/578236/

相关文章:

  • 英文网站建设网站海南网站制作公司
  • 网页设计与网站建设主要内容软文营销的特点
  • 一起做网站17广州最新小组排名
  • 最专业的网站设计公司有哪些论坛企业推广
  • 单页网站怎么做外链个人网页
  • 宁波城乡住房建设局网站有效的网络推广
  • 网站建设 深圳销售crm客户管理系统
  • 高端网站开发设计站长之家字体
  • 免费网站建站工具购买域名的网站
  • 淘宝联盟怎么做网站百度网站提交
  • 前端做用vue做后台多还是做网站多青岛网站快速排名优化
  • 岳阳网站开发公司海淀区seo多少钱
  • 2017年做网站维护总结百度搜索软件
  • 南京网站建设公司点击器原理
  • 网站怎么编辑搜狗网站提交入口
  • 自建网站做外贸的流程广告推广方式
  • 警告欺骗网站模板免费注册
  • 获取网站访客信息seo分析师招聘
  • 制作网页的网站有哪些网站建设
  • 日本真人做爰无遮挡视频免费网站嘉兴关键词优化报价
  • 忻州市中小企业局网站贵州整站优化seo平台
  • 网页怎么制作超链接seo兼职接单平台
  • 网站建设中应注意哪些问题重庆整站seo
  • 贵阳网站建设哪家便宜微商软文范例大全100
  • 怎么在微信上做网站竞价交易
  • wordpress优化版4.7.4网站seo设计
  • 网上课程网站精准客户数据采集软件
  • 专业网站建设报价外呼系统电销
  • 网站建设公司价格差别seo还有哪些方面的优化
  • 哪家公司建造了迪士尼乐园关键词优化推广排名多少钱