vue控制滾動(dòng)條滑到某個(gè)位置的方法實(shí)例
一.關(guān)于web開發(fā)的各種高度的計(jì)算介紹
設(shè)置當(dāng)前滑動(dòng)到的距離
語法一:window.scrollTop(x,y) 傳倆個(gè)值
//x橫坐標(biāo) y縱坐標(biāo)
例:window.scrollTop(0,1000)
語法二:window.scrollTop(options) 傳對(duì)象,對(duì)象里面放屬性
window.scrollTo({
top:560,
left:0,
behavior: "smooth"
});// top:縱坐標(biāo) left:橫坐標(biāo)
behavior 類型String,表示滾動(dòng)行為,支持參數(shù) smooth(平滑滾動(dòng)),instant(瞬間滾動(dòng)),默認(rèn)值auto,實(shí)測(cè)效果等同于instant
// 獲取html元素
let htmlDom = document.documentElement;
// 獲取頁面高度加內(nèi)邊距
const deviceHeight = htmlDom.clientHeight;
//獲取當(dāng)前滾動(dòng)條的高度
const scrollHeight=htmlDom.scrollHeight;
//獲取頁面高度加內(nèi)邊距加邊框
const offsetHeight=htmlDom.offsetHeight;
console.log("html--------",htmlDom.offsetHeight);
console.log("deviceHeight",deviceHeight);
console.log("scrollHeight",htmlDom.scrollHeight);
//我的業(yè)務(wù)里面只用到了這個(gè)scrollHeight
let keepHeight=htmlDom.scrollHeight-90;
// 如果需要設(shè)置某個(gè)元素的樣式等用ref進(jìn)行一個(gè)綁定 這個(gè)例子ref綁定的就是list
// this.$refs.list.style.height = htmlDom.scrollHeight +"px"
window.scrollTo({
top: keepHeight,
behavior: 'instant'
})配個(gè)官方圖理解:

二.回到頁面頂部實(shí)現(xiàn)方法
1. 元素中綁定ref
<div ref="returnTop"></div>
在需要回到頂部的地方加上此代碼
this.$nextTick(() => {
this.$refs.returnTop.scrollTop = 0
})2. 瀏覽器回到頁面頂部 window.scrollTo(0,0),頁面滾動(dòng)
不用多介紹了,上面有。
一個(gè)小例子如下:
window.scrollTo( 0, 100 );
// 設(shè)置滾動(dòng)行為改為平滑的滾動(dòng)
window.scrollTo({
top: 1000,
behavior: "smooth"
});3.使用el-pagination實(shí)現(xiàn)翻頁自動(dòng)回到頂部
定義$scrollTo方法掛載在vue全局
// main.js
Vue.prototype.$scrollTo = (x = 0, y = 0, type = 'smooth') => {
window.scrollTo({
top: x,
left: y,
behavior: type // 滾動(dòng)行為:smooth平滑滾動(dòng),instant瞬間滾動(dòng),默認(rèn)值auto,等同于instant
})
}
// 使用方法
this.$scrollTo()三.總計(jì)一下今天學(xué)到的新知識(shí)
(1)watch監(jiān)聽屬性變化函數(shù)
監(jiān)聽屬性的兩種寫法:
isHot:{
// immediate:true, //初始化時(shí)讓handler調(diào)用一下
//handler什么時(shí)候調(diào)用?當(dāng)isHot發(fā)生改變時(shí)。
//deep:true, //開啟深度監(jiān)視,當(dāng)屬性是個(gè)對(duì)象時(shí),如需監(jiān)聽對(duì)象的屬性,需開啟深度監(jiān)視
handler(newValue,oldValue){
console.log('isHot被修改了',newValue,oldValue)
}
},
//簡寫
/* isHot(newValue,oldValue){
console.log('isHot被修改了',newValue,oldValue,this)
} */watch監(jiān)聽函數(shù)實(shí)現(xiàn)compted函數(shù)相同功能
data:{
firstName:'張',
lastName:'三',
fullName:'張-三'
},
watch:{
firstName(val){
//監(jiān)聽函數(shù)可以實(shí)現(xiàn)異步方法
setTimeout(()=>{
console.log(this)
this.fullName = val + '-' + this.lastName
},1000);
},
lastName(val){
this.fullName = this.firstName + '-' + val
}
}(2)computed和watch之間的區(qū)別:
1.computed能完成的功能,watch都可以完成。
2.watch能完成的功能,computed不一定能完成,例如:watch可以進(jìn)行異步操作。
但是computed進(jìn)行計(jì)算某些值得時(shí)候,可以少寫一個(gè)屬性。例如:fullName
補(bǔ)充:vue平滑滾動(dòng)到指定位置
需求:錨點(diǎn)導(dǎo)航問題,點(diǎn)擊導(dǎo)航跳到對(duì)應(yīng)的模塊,兩種方式
1.滾動(dòng)盒子滾動(dòng)到指定高度 scrollTo(offsetTop每個(gè)模塊頂部距離可滾動(dòng)盒子的頂部偏移的像素值)
goAnthor (selector) {
const height = document.querySelector(selector).offsetTop
const container = document.querySelector('.scroll-wrap')
container.scrollTo({
top: height,
behavior: 'smooth'
})
},
2.滾動(dòng)元素滾動(dòng)到滾動(dòng)盒子的最頂部 scrollIntoView
goAnthor(selector) {
document.querySelector(selector).scrollIntoView({
behavior: 'smooth'
})
},
總結(jié)
到此這篇關(guān)于vue控制滾動(dòng)條滑到某個(gè)位置的文章就介紹到這了,更多相關(guān)vue控制滾動(dòng)條滑到某位置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue2?Element?description組件列合并詳解
在使用Vue的時(shí)候經(jīng)常會(huì)涉及到表格的列合并,下面這篇文章主要給大家介紹了給大家Vue2?Element?description組件列合并的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
vue項(xiàng)目webpack中配置src路徑別名及使用方式
這篇文章主要介紹了vue項(xiàng)目webpack中配置src路徑別名及使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
詳解vue express啟動(dòng)數(shù)據(jù)服務(wù)
本篇文章主要介紹了vue express啟動(dòng)數(shù)據(jù)服務(wù),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
vue-router實(shí)現(xiàn)嵌套路由的講解
今天小編就為大家分享一篇關(guān)于vue-router實(shí)現(xiàn)嵌套路由的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-01-01
vue elementUI 表單嵌套驗(yàn)證的實(shí)例代碼
這篇文章主要介紹了vue + elementUI 表單嵌套驗(yàn)證,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-11-11

