vue頁(yè)面加載時(shí)的進(jìn)度條功能(實(shí)例代碼)
先看一張圖

如果我們的程序每次頁(yè)面切換時(shí),頂部也有一個(gè)進(jìn)度條,那會(huì)讓用戶(hù)體驗(yàn)提升很大的。
npropgress插件
簡(jiǎn)單用法 - Vue 項(xiàng)目為例(詳細(xì)配置,點(diǎn)擊上面的github地址查看文檔)
最簡(jiǎn)單的使用方式:vue項(xiàng)目的每次路由切換時(shí),都加載進(jìn)度條
安裝
npm install --save nprogress
引入
在路由配置文件中引入,寫(xiě)到路由加載前和加載后的兩個(gè)鉤子函數(shù)中
// 引入
import NProgress from 'nprogress';
import 'nprogress/nprogress.css';
// 進(jìn)度條配置項(xiàng)這樣寫(xiě)
NProgress.configure({
showSpinner: false
});
// 路由跳轉(zhuǎn)前鉤子函數(shù)中 - 執(zhí)行進(jìn)度條開(kāi)始加載
router.beforeEach((to, from, next) => {
NProgress.start();
});
// 路由跳轉(zhuǎn)后鉤子函數(shù)中 - 執(zhí)行進(jìn)度條加載結(jié)束
router.afterEach(() => {
NProgress.done();
});
如果是 cdn 引入的話,如下
<script src='nprogress.js'></script> <link rel='stylesheet' href='nprogress.css'/>
設(shè)置進(jìn)度條顏色
如果是一般的 vue 項(xiàng)目,把樣式放到一個(gè)css文件中,在項(xiàng)目主文件main.js中引入,下面是 css 樣式
#nprogress .bar {
background: #00CC00 !important; //自定義顏色
}
配置項(xiàng)
手動(dòng)控制進(jìn)度條遞增,參數(shù)范圍是0 - 1,不傳參數(shù)的話,每次調(diào)用都會(huì)隨機(jī)遞增,但永遠(yuǎn)不會(huì)到達(dá) 100% ,除非調(diào)用NProgress.done();
// 調(diào)用之前如果進(jìn)度條的狀態(tài) 50% NProgress.inc(0.2); // 調(diào)用之后 70%
進(jìn)度條加載完成
帶參數(shù)true:即使沒(méi)有調(diào)用NProgress.start(),也會(huì)顯示并執(zhí)行進(jìn)度條從 0% - 100% 的狀態(tài),然后消失。
不帶參數(shù):如果沒(méi)有調(diào)用NProgress.start(),那么此命令不會(huì)執(zhí)行任何操作。
NProgress.done(true);
啟動(dòng)進(jìn)度條時(shí)的最小百分比(默認(rèn)為 0.08)
NProgress.configure({
minimum: 0.3
});
可以使用模板更改標(biāo)記。要保持進(jìn)度條正常工作,要在其中保留一個(gè)role='bar'元素,參考默認(rèn)模板。
// 默認(rèn)模板
NProgress.configure({
template: "<div class='....'>...</div>"
});
// 舉例
NProgress.configure({
template: "<div class='other-instance'><div role='bar'>更改標(biāo)記</div></div>"
})
使用 easing 和 speed 調(diào)整動(dòng)畫(huà)設(shè)置,ease可傳遞CSS3緩沖動(dòng)畫(huà)字符串(如ease、linear、ease-in、ease-out、ease-in-out、cubic-bezier),speed為動(dòng)畫(huà)速度(單位ms)。默認(rèn)分別為 ease 200
NProgress.configure({
easing: 'ease',
speed: 200
});
關(guān)閉自動(dòng)遞增行為
NProgress.configure({
trickle: false
});
調(diào)整遞增的頻率,單位為毫秒
NProgress.configure({
trickleSpeed: 200
});
關(guān)閉微調(diào)器,默認(rèn)為開(kāi)啟狀態(tài)(上圖中右上角的那個(gè)圓圈加載圖標(biāo))
NProgress.configure({
showSpinner: false,
});
更改父容器
NProgress.configure({
parent:'#container'
});
總結(jié)
以上所述是小編給大家介紹的vue頁(yè)面加載時(shí)的進(jìn)度條功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
Vue實(shí)現(xiàn)簡(jiǎn)單分頁(yè)器
這篇文章主要為大家詳細(xì)介紹了Vue實(shí)現(xiàn)簡(jiǎn)單分頁(yè)器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
Vue高級(jí)組件之函數(shù)式組件的使用場(chǎng)景與源碼分析
Vue提供了一種稱(chēng)為函數(shù)式組件的組件類(lèi)型,用來(lái)定義那些沒(méi)有響應(yīng)數(shù)據(jù),也不需要有任何生命周期的場(chǎng)景,它只接受一些props來(lái)顯示組件,下面這篇文章主要給大家介紹了關(guān)于Vue高級(jí)組件之函數(shù)式組件的使用場(chǎng)景與源碼分析的相關(guān)資料,需要的朋友可以參考下2021-11-11
vue 重塑數(shù)組之修改數(shù)組指定index的值操作
這篇文章主要介紹了vue 重塑數(shù)組之修改數(shù)組指定index的值操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08
webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法(總結(jié)篇)
這篇文章主要介紹了解決webpack vue 項(xiàng)目打包生成的文件,資源文件報(bào)404問(wèn)題的修復(fù)方法,需要的朋友可以參考下2018-01-01
Vue實(shí)現(xiàn)在線預(yù)覽pdf文件功能(利用pdf.js/iframe/embed)
項(xiàng)目要求需要預(yù)覽pdf文件,網(wǎng)上找了很久,發(fā)現(xiàn)pdf.js的效果,這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)在線預(yù)覽pdf文件功能,主要利用pdf.js/iframe/embed來(lái)實(shí)現(xiàn)的,需要的朋友可以參考下2021-06-06
element表單el-form的label自適應(yīng)寬度的實(shí)現(xiàn)
本文主要介紹了element表單el-form的label自適應(yīng)寬度的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
vue中關(guān)于computed的this指向問(wèn)題
這篇文章主要介紹了vue中關(guān)于computed的this指向問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
Vue.js實(shí)現(xiàn)移動(dòng)端短信驗(yàn)證碼功能
現(xiàn)在的短信驗(yàn)證碼一般為4位或6位,則頁(yè)面中會(huì)相應(yīng)的顯示4個(gè)或6個(gè)文本框.好多網(wǎng)站需求都有此功能,今天小編給大家分享基于vue.js實(shí)現(xiàn)移動(dòng)端短信驗(yàn)證碼功能,需要的朋友參考下吧2017-03-03
Vue3 Vant組件庫(kù)使用過(guò)程中的避坑點(diǎn)
本片文章主要寫(xiě)了,Vue3開(kāi)發(fā)時(shí)運(yùn)用Vant UI庫(kù)的一些避坑點(diǎn)。讓有問(wèn)題的小伙伴可以快速了解是為什么。也是給自己做一個(gè)記錄2023-04-04

