vue實(shí)現(xiàn)中部導(dǎo)航欄布局功能
接下來是中部導(dǎo)航欄。我們看到這里的頭像動(dòng)畫,和中部導(dǎo)航欄定位都是跟鼠標(biāo)滾動(dòng)有關(guān)的。我們先將布局實(shí)現(xiàn)一下。這里是要求在頁面上部分滾動(dòng)范圍內(nèi),導(dǎo)航欄一直在div的上部,隨著鼠標(biāo)的滾動(dòng)而改變位置。到下部分滾動(dòng)范圍,導(dǎo)航欄就一直固定到頁面的上部分。
這里需要注意兩個(gè)地方
這里需要一個(gè)覆蓋不了的區(qū)域,可以給人一種更好開關(guān)屏的感覺。而且中部導(dǎo)航欄下方區(qū)域的內(nèi)容,在下滑的時(shí)候不能出現(xiàn)在這個(gè)區(qū)域。

一定要注意 盡可能的少進(jìn)行DOM操作,這樣是非常影響性能的 !
監(jiān)聽鼠標(biāo)滾動(dòng)事件
private fixedFlag: boolean = false;
private unFixedFlag: boolean = true;
private mounted() {
window.addEventListener("scroll", this.handleScroll);
}
private handleScroll() {
const scrollTop =
window.pageYOffset ||
document.documentElement.scrollTop ||
document.body.scrollTop;
if (scrollTop > 300) {
if (!this.fixedFlag) {
const obj = document!.getElementById("index-menu");
const obj2 = document!.getElementById("fake-area");
obj!.style.position = "fixed";
obj!.style.top = "77px";
obj2!.style.position = "fixed";
obj2!.style.top = "47px";
this.fixedFlag = true;
this.unFixedFlag = false;
}
} else {
if (!this.unFixedFlag) {
const obj = document!.getElementById("index-menu");
const obj2 = document!.getElementById("fake-area");
obj!.style.position = "";
obj!.style.top = "";
obj2!.style.position = "";
obj2!.style.top = "";
this.unFixedFlag = true;
this.fixedFlag = false;
}
}
}
效果展示

項(xiàng)目地址
https://github.com/pppercyWan...
總結(jié)
以上所述是小編給大家介紹的vue實(shí)現(xiàn)中部導(dǎo)航欄布局功能,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
FastApi+Vue+LayUI實(shí)現(xiàn)前后端分離的示例代碼
本文主要介紹了FastApi+Vue+LayUI實(shí)現(xiàn)前后端分離的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
vue項(xiàng)目中如何將當(dāng)前頁面生成圖片
這篇文章主要介紹了vue項(xiàng)目中如何將當(dāng)前頁面生成圖片問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
Vue輸入框狀態(tài)切換&自動(dòng)獲取輸入框焦點(diǎn)的實(shí)現(xiàn)方法
這篇文章主要介紹了Vue輸入框狀態(tài)切換&自動(dòng)獲取輸入框焦點(diǎn)的實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05
以v-model與promise兩種方式實(shí)現(xiàn)vue彈窗組件
這篇文章主要介紹了vue彈窗組件之兩種方式v-model與promise,每種方式給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-05-05
Vant picker 多級(jí)聯(lián)動(dòng)操作
這篇文章主要介紹了Vant picker 多級(jí)聯(lián)動(dòng)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-11-11
通過一個(gè)簡單的例子學(xué)會(huì)vuex與模塊化
這篇文章主要給大家介紹了關(guān)于如何通過一個(gè)簡單的例子學(xué)會(huì)vuex與模塊化的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-11-11

