Vue項(xiàng)目頁(yè)面跳轉(zhuǎn)時(shí)瀏覽器窗口上方顯示進(jìn)度條功能
在vue項(xiàng)目中,為了減少首屏加載的時(shí)間,通常會(huì)開啟路由的懶加載。路由懶加載配合gizp確實(shí)能幫助我們大大的加快首屏的加載時(shí)間。
然而,路由懶加載會(huì)使得我們?cè)诘谝淮未蜷_一個(gè)新頁(yè)面的時(shí)候,會(huì)有一個(gè)加載時(shí)間。如果在這個(gè)時(shí)候我們沒有一個(gè)提示的話,給人的感覺會(huì)是好像我點(diǎn)了頁(yè)面跳轉(zhuǎn)但是沒反應(yīng)。所以,這個(gè)時(shí)候我們可以加一個(gè)進(jìn)度條來(lái)告知用戶。
具體實(shí)現(xiàn),我們使用NProgress這個(gè)滾動(dòng)條效果插件。
1.安裝:
cnpm install --save nprogress
2.在main.js中引入:
import NProgress from ’nprogress’ import ’nprogress/nprogress.css’
3.在main.js中進(jìn)行配置:
NProgress.configure({ easing: ’ease’, // 動(dòng)畫方式 speed: 500, // 遞增進(jìn)度條的速度 showSpinner: false, // 是否顯示加載ico trickleSpeed: 200, // 自動(dòng)遞增間隔 minimum: 0.3 // 初始化時(shí)的最小百分比})
4.在main.js中對(duì)路由鉤子進(jìn)行設(shè)置:
//當(dāng)路由進(jìn)入前 router.beforeEach((to, from , next) => { // 每次切換頁(yè)面時(shí),調(diào)用進(jìn)度條 NProgress.start(); // 若加載時(shí)間長(zhǎng)且不定,擔(dān)心進(jìn)度條走完都沒有加載完,可以調(diào)用NProgress.inc();//這會(huì)以隨機(jī)數(shù)量遞增,且永遠(yuǎn)達(dá)不到100%,也可以設(shè)指定增量 next(); });//當(dāng)路由進(jìn)入后:關(guān)閉進(jìn)度條router.afterEach(() => { // 在即將進(jìn)入新的頁(yè)面組件前,關(guān)閉掉進(jìn)度條 NProgress.done()})
補(bǔ)充:vue頁(yè)面跳轉(zhuǎn)方法
vue2.0在使用的過(guò)程中, .vue文件之間的跳轉(zhuǎn),需要在router里面配置path,通過(guò)路徑跳轉(zhuǎn),html文件跳轉(zhuǎn)如下:
<router-link to='/path'><button>跳轉(zhuǎn)</button></router-link>
但是有時(shí)的需求是頁(yè)面不直接跳轉(zhuǎn),有確認(rèn)彈框或者其他事件,此時(shí)就需要在js中設(shè)置跳轉(zhuǎn),方法如下:
this.$ router.push({path: ‘/…’}); path為跳轉(zhuǎn)路徑,此方法會(huì)產(chǎn)生歷史記錄this.$ router.push({name:’…’}) name也可以作為路由跳轉(zhuǎn)this.$ router.push({path:‘home’,query:{obj:’…’}}) query:參數(shù),可通過(guò)this.$ route.query.obj獲取this.$ router.push({path:‘home’,params:{obj:’…’}}) query:參數(shù),可通過(guò)this.$route.params.obj獲取this.$router.replace() 此方法不會(huì)產(chǎn)生歷史記錄this.$router.go(n) 向前或向后跳轉(zhuǎn)n個(gè)頁(yè)面
總結(jié)
到此這篇關(guān)于Vue項(xiàng)目頁(yè)面跳轉(zhuǎn)時(shí)瀏覽器窗口上方顯示進(jìn)度條功能的文章就介紹到這了,更多相關(guān)vue 頁(yè)面跳轉(zhuǎn)進(jìn)度條內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. IDEA巧用Postfix Completion讓碼速起飛(小技巧)2. Python如何批量獲取文件夾的大小并保存3. docker /var/lib/docker/aufs/mnt 目錄清理方法4. CSS代碼檢查工具stylelint的使用方法詳解5. Python中Selenium模塊的使用詳解6. Python的Tqdm模塊實(shí)現(xiàn)進(jìn)度條配置7. Python 多線程之threading 模塊的使用8. CSS3中Transition屬性詳解以及示例分享9. IntelliJ IDEA2020.2.2創(chuàng)建Servlet方法及404問(wèn)題10. Python基于smtplib模塊發(fā)送郵件代碼實(shí)例
