這篇文章主要介紹了vue使用原生js實現滾動頁面跟蹤導航高亮的方法,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。
需要使用vue做一個專題頁面。
滾動頁面指定區域導航高亮。
監聽滾動頁面事件,對比當前頁面的位置與元素的位置,如果當前滾動的區域位置大于元素的位置,導航添加class,其他去掉class進行樣式切換。
我使用的方法是在定位元素上添加id,在導航添加data-id屬性,監聽滾動事件,如果當前滾動區域大于定位元素區域,將元素的id賦值給變量,然后與導航的data-id進行匹配,切換class。
main.vue
<template>
<div class="qz-home">
<div class="quiz-container">
<div class="quiz-ad-pic" id="pagetop"></div>
<div class="quiz-main">
<div class="quiz-main-inside" id="js-content">
<quiz-sessions class="item" id="quizhall"></quiz-sessions>
<quizRecords class="item" id="quizrecord"></quizRecords>
<quiz-history class="item" id="quizHistory"></quiz-history>
<quiz-mine class="item" id="quizMine"></quiz-mine>
<quiz-rank class="item" id="quizRank"></quiz-rank>
<quiz-rule class="item" id="quizRule"></quiz-rule>
</div>
</div>
<navigation id="js-nav"></navigation>
</div>
</div>
</template>navigation.vue
<template>
<nav class="nav-container">
<div class="nav-mark"></div>
<div class="nav-main">
<ul class="nav-list">
<li :class="{'cur': curindex === index}" v-for="(item, index) in navList" :key="index" :data-id="item.id"><a @click="linkTo(item.id, index)">{{item.name}}</a></li>
</ul>
<div class="backtop" @click="backTop()">
<a></a>
</div>
</div>
</nav>
</template>javascript
export default {
name: "Navigation",
data() {
return {
navList: [
{ name: "競猜大廳", id: "quizhall" },
{ name: "競猜記錄", id: "quizrecord" },
{ name: "歷史賽事", id: "quizHistory" },
{ name: "我的競猜", id: "quizMine" },
{ name: "排行榜", id: "quizRank" },
{ name: "玩法", id: "quizRule" }
],
curindex: 0
};
},
mounted() {
this.initScroll();
},
methods: {
initScroll() {
let _this = this;
// 監聽頁面滾動事件
window.addEventListener('scroll', function() {
var removeClass = function(obj, cls) {
if (obj.className == cls) {
obj.className = "";
}
}
var addClass = function(obj, cls) {
if (obj.className != cls) {
obj.className = cls;
}
}
let pos = document.documentElement.scrollTop;
if (pos > 300) {
_this.isVisibleNav = true;
} else {
_this.isVisibleNav = false;
}
// 獲取全部導航dom與元素dom
var navList = document.querySelector("#js-nav").querySelectorAll("li");
var items = document.querySelector("#js-content").querySelectorAll(".item");
// 滾動后遍歷元素,如果頁面滾動位置大于元素的位置,賦值給變量
var currentId = "";
for (var i = 0; i < items.length; i++) {
var _item = items[i];
var _itemTop = _item.offsetTop;
if (pos > _itemTop - 200) {
currentId = _item.id;
} else {
break;
}
}
// 如果已賦值了變量,進行匹配,如果匹配則添加class其他刪除
if (currentId) {
for (var j = 0; j < navList.length; j++) {
var _navItem = navList[j];
var _navId = _navItem.getAttribute('data-id');
if (_navId != currentId) {
removeClass(_navItem, "cur");
} else {
addClass(_navItem, "cur");
}
}
}
})
}
}
};感謝你能夠認真閱讀完這篇文章,希望小編分享vue使用原生js實現滾動頁面跟蹤導航高亮的方法內容對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,遇到問題就找億速云,詳細的解決方法等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。