vue路由切换loading_vue-router懒加载时添加loading提示提升用户体验

这次给大家带来vue-router懒加载时添加loading提示提升用户体验,vue-router懒加载时添加loading提示提升用户体验的注意事项有哪些,下面就是实战案例,一起来看一下。

用过vue-router都知道它可以实现模块js的懒加载,即只有当需要时才去加载对应模块的js脚本文件,以加速主页的显示。比如只有第一次用户点击某个“用户信息”按钮或菜单时,才下载“用户信息”这个模块的js组件。

懒加载的实现,依赖与webpack下AMD模式require函数的功能。webpack会将异步require的文件生成一个独立的js文件,调用时异步下载这个js且在完成后再执行它。开发项目中实现的关键代码是:const basicInfo = {

path: '/user',

component: resolve => require(['./basicInfo.vue'], resolve)

}

//然后将这个basicInfo加入路由表中

但是这里有个问题:从用户点击“用户信息”菜单开始,到js文件下载完毕执行开始,由于从网络下载js有一个时间延迟,这期间用户界面是没有任何响应的,让用户感觉点上去无效,常会重复再次点击。特别是js文件大而网速慢时更明显。因此,在这个过程中添加一个Loading的加载提示很有必要。

我们分析这行代码:resolve => require(['./basicInfo.vue'], resolve)

它是一个函数,执行了require的过程,完成后再调用resolve回调函数。我们只要封装一下,在require执行之前显示Loading,然后在加载完成执行回调的时候隐藏Loading,也就实现这个需求了。如下:const basicInfo = {

path: '/user',

component: resolve => {

[显示Loading]

require(['./basicInfo.vue'], component => {

[隐藏Loading]

resolve(component)

})

}

};

显示和隐藏Loading的代码,可根据自己的UI框架处理就行。比如element-ui:import { Loading } from 'element-ui';

var unique;

export default {

show() {

let opt = {body: true, text: 'Loading...'};

if(!unique) unique = Loading.service(opt);

},

resolve(resolve) {

return function (component) {

if (unique) {

unique.close();

unique = null;

}

resolve(component)

}

}

}

const basicInfo = {

path: '/user',

component: resolve => {

spinRoute.show();

require(['./basicInfo.vue'], spinRoute.resolve(resolve))

}

};

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以在 Vue Router 中使用 Navigation Guards 来实现路由切换loading 效果。具体做法如下: 1. 在你的 Vue 组件中添加一个 loading 状态,用于控制 loading 效果的显示和隐藏。 2. 在 Vue Router 中定义一个前置守卫(beforeEach),用于在路由切换改变 loading 状态。 3. 在 Vue Router 中定义一个后置守卫(afterEach),用于在路由切换完成后恢复 loading 状态。 下面是一个简单的示例代码: ```javascript // App.vue <template> <div> <router-view></router-view> <div v-show="loading" class="loading">Loading...</div> </div> </template> <script> export default { data() { return { loading: false, }; }, }; </script> // router/index.js import Vue from 'vue'; import Router from 'vue-router'; Vue.use(Router); const router = new Router({ mode: 'history', routes: [ { path: '/', name: 'Home', component: () => import('@/views/Home.vue'), }, { path: '/about', name: 'About', component: () => import('@/views/About.vue'), }, ], }); router.beforeEach((to, from, next) => { // 显示 loading router.app.loading = true; next(); }); router.afterEach(() => { // 隐藏 loading router.app.loading = false; }); export default router; ``` 在上面的示例中,我们在 App.vue 组件中添加了一个 loading 状态,并使用 v-show 指令控制其显示和隐藏。在 router/index.js 文件中,我们定义了一个前置守卫,用于在路由切换显示 loading,同定义了一个后置守卫,用于在路由切换完成后隐藏 loading。这样就可以实现路由切换loading 效果了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值