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

深圳做网站媒体宣传推广方案

深圳做网站,媒体宣传推广方案,专业做网站app的公司有哪些,自己建设的网站打开慢文章目录 原因解决方案方案1(尝试且有效)方案2方案3 之前在写项目时,用到了进度条插件(效果如下),但是遇到了一个比较影响用户体验的问题,就是当路由还没进行跳转,进度条已经加载完&…

文章目录

  • 原因
  • 解决方案
    • 方案1(尝试且有效)
    • 方案2
    • 方案3

之前在写项目时,用到了进度条插件(效果如下),但是遇到了一个比较影响用户体验的问题,就是当路由还没进行跳转,进度条已经加载完,也就是说,用户想要进入其他页面时,明明已经看到进度条加载完了,但是仍然停留在当前页面,进度条完成之后还要等待一段时间,路由才能进行跳转
在这里插入图片描述

nprogress.configure({easing: "ease",speed: 800, // 增加速度让进度条走得慢一些showSpinner: false, // 显示spinner让用户知道在加载trickleSpeed: 100, // 减慢自动递增速度minimum: 0.1, // 降低最小值
});router.beforeEach((to: any, from: any, next: any) => {const userStore = useUserStore();let permissions = userStore.permissions;nprogress.start();const token = getLocalStorageWithExpire("token");// 白名单:登录页,首页和报名页不需要 tokenif (to.path === "/login" || to.path === "/" || to.path === "/application") {if (token) {// 已登录时特殊处理if (to.path === "/login") {// 已登录访问登录页,跳转到首页return next("/");} else if (to.path === "/application") {// 已登录访问报名页,跳转首页并提示showAlert("已登录用户不可访问报名页", "error");return next("/");}}// 其他白名单情况正常放行return next();}// 未登录且访问其他页面,跳转登录页if (!token) {return next("/login");}// 权限判断if (to.path.startsWith("/admin") && !permissions.includes(to.meta.roles)) {router.push("/404");}next();
});
//关键所在router.afterEach((to: any, from: any) => {nprogress.done();
});

原因

后来在控制台查看了网络请求,发现网络请求时间过长,
因此也就有了一个推测:
NProgress 在 router.afterEach 中结束,但此时懒加载的组件可能还在kukuku的网络请求中
路由已经"跳转完成",但组件内容还没加载完

解决方案

方案1(尝试且有效)

使用beforeResolve,这样进度条会等待组件懒加载完成(关键)
修改nprogress 设置,让其慢一些(这个可改可不改)

router.beforeResolve((to, from, next) => {// 此时组件已经加载完成,地址栏也会更新nprogress.done();next();
});
nprogress.configure({easing: "ease",speed: 800, // 增加速度让进度条走得慢一些showSpinner: false, // 显示spinner让用户知道在加载trickleSpeed: 100, // 减慢自动递增速度minimum: 0.1, // 降低最小值
});

方案2

处理懒加载组件的加载状态
由于项目使用的是自动导入路由,这个方法没有试

// 创建一个包装函数来处理懒加载
function lazyLoadComponent(importFunc) {return () => {NProgress.start()return importFunc().then(module => {NProgress.done()return module}).catch(error => {NProgress.done()console.error('组件加载失败:', error)throw error})}
}// 使用包装函数
const routes = [{path: '/',name: 'Home',component: lazyLoadComponent(() => import('@/views/Home.vue'))},{path: '/about',name: 'About',component: lazyLoadComponent(() => import('@/views/About.vue'))}
]

方案3

使用全局混入

app.mixin({async beforeRouteEnter(to, from, next) {NProgress.done()next()}
})
http://www.dtcms.com/wzjs/294043.html

相关文章:

  • 服务类网站banner杭州seo论坛
  • 网站pc端建设seo全网营销的方式
  • 代理公司是干什么的win11优化大师
  • 泌阳专业网站建设互联网营销的五个手段
  • 娄底住房和城乡建设部网站sem推广和seo的区别
  • 做网站推广的需要了解哪些知识地推推广平台
  • 域名备案要先做网站的吗百度代理服务器
  • 梧州网站建设流程整合营销传播方法包括
  • 怎么制作动态的网站seo推广费用
  • 网站接入银联支付怎么做产品宣传推广方式有哪些
  • 专业做网站路桥百度推广官方电话
  • 网站开发维护合同样板电子商务平台有哪些
  • 网站信息系统设计网络推广是什么
  • 开封市住房和城乡建设局网站西昌seo快速排名
  • 湖南张家界建设局网站什么平台可以推销自己的产品
  • 网站建设 学生作业产品推广文案怎么写
  • 女孩子学做网站有前途吗系统清理优化工具
  • 上海网站推广多少钱家庭优化大师免费下载
  • 做的网站上传到服务器百度推广创意范例
  • 济宁网站建设软件开发北京seo推广服务
  • 张店网站设计百度手机版网址
  • 专业搭建网站四年级的简短新闻播报
  • ps怎么做网站设计网络营销的成功案例
  • web前端开发工具有哪些杭州seo平台
  • 人大网站建设公司百度官网优化
  • 手机网站需要域名吗企业微信营销管理软件
  • 做公司网站用什么系统网络推广公司简介模板
  • 县文化馆网站建设方案中央常委成员名单
  • 上海崇明网站建设重庆网络推广平台
  • 建设电商网站企业培训内容