vue+jquery+lodash實(shí)現(xiàn)滑動(dòng)時(shí)頂部懸浮固定效果
本文實(shí)例為大家分享了vue實(shí)現(xiàn)滑動(dòng)時(shí)頂部懸浮固定效果的具體代碼,供大家參考,具體內(nèi)容如下
這個(gè)效果是一個(gè)項(xiàng)目中抽出來(lái)的一個(gè)demo效果。

前期準(zhǔn)備:
1. 引入jQ
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script>
引入lodash.js
npm install lodash -D
fixTop.vue組件的
<template>
<div class="fixtop2">
<header class="header" ref="header"></header>
<div class="nav" ref="nav" :class="{isFixed:isFixed}">
<div class="box" v-for="(item,index) in list" :key="index">
{{item.title}}
</div>
</div>
<ul class="content">
<li v-for="(item,index) in new Array(20)" :key="index">{{index+1}}</li>
</ul>
</div>
</template>
<script>
var throttle = require('lodash/throttle'); //從lodash中引入的throttle節(jié)流函數(shù)
export default {
name: 'navScroll2',
data() {
return {
list: [
{ title: 'AAAA', id: 1 },
{ title: 'BBBB', id: 2 },
{ title: 'CCCC', id: 3 },
{ title: 'DDDD', id: 4 },
],
isFixed: false, //是否固定的
throttleScroll: null, //定義一個(gè)截流函數(shù)的變量
};
},
methods: {
//滾動(dòng)的函數(shù)
handleScroll() {
let h = $(this.$refs.header).outerHeight(); //header的高度
let wh = $(window).scrollTop(); //滾動(dòng)的距離的,為什么這里使用的jq,因?yàn)椴挥每紤]的什么的兼容問(wèn)題
let navH = $(this.$refs.nav).outerHeight(); //nav的高度
if (wh > h) {
this.isFixed = true;
} else {
this.isFixed = false;
}
},
},
mounted() {
//寫(xiě)在掉接口的里面的
this.$nextTick(() => {
//這里使用監(jiān)聽(tīng)的scroll的事件,為什么要使用的節(jié)流函數(shù),如果不使用的,頁(yè)面一直在滾動(dòng)計(jì)算的,這樣在
//使用手機(jī)時(shí)候,出現(xiàn)非常卡的,隔一段時(shí)間計(jì)算,大大降低了性能的消耗(具體的好處自己去查資料)
window.addEventListener('scroll', this.throttleScroll, false);
});
this.throttleScroll = throttle(this.handleScroll, 100);
},
deactivated() {
//離開(kāi)頁(yè)面需要remove這個(gè)監(jiān)聽(tīng)器,不然還是卡到爆。
window.removeEventListener('scroll', this.throttleScroll);
},
};
</script>
<style lang="scss" scoped>
.fixtop2 {
min-height: 100vh;
}
.header {
height: 5rem;
width: 100%;
background-color: red;
}
.nav {
display: flex;
width: 100%;
background-color: pink;
&.isFixed {
position: fixed;
left: 0;
top: 0;
z-index: 9999;
}
.box {
font-size: 0.3rem;
padding: 0 0.3rem;
height: 0.9rem;
line-height: 0.9rem;
color: #333333;
flex: 1;
}
}
.content {
height: 20rem;
li {
width: 100%;
height: 1rem;
border-bottom: 1px solid #000;
}
}
</style>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue實(shí)現(xiàn)移動(dòng)端懸浮窗效果
- vue懸浮可拖拽懸浮按鈕的實(shí)例代碼
- vue中element-ui表格縮略圖懸浮放大功能的實(shí)例代碼
- Vue在頁(yè)面右上角實(shí)現(xiàn)可懸浮/隱藏的系統(tǒng)菜單
- Vue實(shí)現(xiàn)鼠標(biāo)經(jīng)過(guò)文字顯示懸浮框效果的示例代碼
- Vue.js鼠標(biāo)懸浮更換圖片功能
- Vue實(shí)現(xiàn)PC端靠邊懸浮球的代碼
- vue實(shí)現(xiàn)可移動(dòng)的懸浮按鈕
- vue 實(shí)現(xiàn)超長(zhǎng)文本截取,懸浮框提示
- vue實(shí)現(xiàn)懸浮球效果
相關(guān)文章
element-plus的el-table自定義表頭篩選查詢(xún)功能實(shí)現(xiàn)
這篇文章主要介紹了element-plus的el-table自定義表頭篩選查詢(xún)功能實(shí)現(xiàn),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-07-07
VUE登錄注冊(cè)頁(yè)面完整代碼(直接復(fù)制)
這篇文章主要給大家介紹了關(guān)于VUE登錄注冊(cè)頁(yè)面的相關(guān)資料,在Vue中可以使用組件來(lái)構(gòu)建登錄注冊(cè)頁(yè)面,文中通過(guò)圖文以及代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
vueRouter--matcher之動(dòng)態(tài)增減路由方式
這篇文章主要介紹了vueRouter--matcher之動(dòng)態(tài)增減路由方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
element表單使用校驗(yàn)之校驗(yàn)失效問(wèn)題詳解
最近工作中遇到了element表單校驗(yàn)失敗的情況,通過(guò)查找相關(guān)資料終于解決了,所以下面這篇文章主要給大家介紹了關(guān)于element表單使用校驗(yàn)之校驗(yàn)失效問(wèn)題的相關(guān)資料,需要的朋友可以參考下2022-10-10
詳解在Vue中如何使用axios跨域訪問(wèn)數(shù)據(jù)
本篇文章主要介紹了在Vue中如何使用axios跨域訪問(wèn)數(shù)據(jù),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07
vue中使用element組件時(shí)事件想要傳遞其他參數(shù)的問(wèn)題
這篇文章主要介紹了vue中使用element組件時(shí)事件想要傳遞其他參數(shù)的問(wèn)題,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09

