Vue中scrollIntoView()方法詳解與實(shí)際運(yùn)用舉例
前言
因?yàn)楣ぷ髦杏玫搅隋^點(diǎn)設(shè)置,滾動(dòng)定位到列表的某一行,常用的總是出問(wèn)題,后來(lái)扒拉出了這個(gè)屬性,詳細(xì)研究了下方便 日 后使用
一、介紹scrollIntoView()的詳細(xì)屬性
1、簡(jiǎn)介
該scrollIntoView()方法將調(diào)用它的元素滾動(dòng)到瀏覽器窗口的可見(jiàn)區(qū)域。
- 根據(jù)其他元素的布局,元素可能無(wú)法完全滾動(dòng)到頂部或底部。
- 頁(yè)面(容器)可滾動(dòng)時(shí)才有用!
2、語(yǔ)法
element.scrollIntoView(); // 等同于element.scrollIntoView(true) element.scrollIntoView(alignToTop); //布爾參數(shù) element.scrollIntoView(scrollIntoViewOptions); //對(duì)象參數(shù)
3、語(yǔ)法參數(shù)
| align To Top | [可選],目前之前這個(gè)參數(shù)得到了良好的支持 |
|---|---|
| true | 元素的頂部將對(duì)齊到可滾動(dòng)祖先的可見(jiàn)區(qū)域的頂部。對(duì)應(yīng)于scrollIntoViewOptions: {block: “start”, inline: “nearest”}。這是默認(rèn)值 |
| false | 元素的底部將與可滾動(dòng)祖先的可見(jiàn)區(qū)域的底部對(duì)齊。對(duì)應(yīng)于scrollIntoViewOptions: {block: “end”, inline: “nearest”}。 |
| scrollIntoViewOptions | [可選],目前這個(gè)參數(shù)瀏覽器對(duì)它的支持并不好,可以查看下文兼容性詳情 |
|---|---|
| behavior | [可選]定義過(guò)渡動(dòng)畫(huà)。“auto”,“instant"或"smooth”。默認(rèn)為"auto"。 |
| block | [可選] “start”,“center”,“end"或"nearest”。默認(rèn)為"center"。 |
| inline | [可選] “start”,“center”,“end"或"nearest”。默認(rèn)為"nearest"。 |
4、示例
var element = document.getElementById("box");
element.scrollIntoView();
element.scrollIntoView(false);
element.scrollIntoView({block: "end"});
element.scrollIntoView({behavior: "instant", block: "end", inline: "nearest"});
5、應(yīng)用場(chǎng)景
URL中hash標(biāo)記的進(jìn)化
聊天窗口滾動(dòng)顯示最新的消息
往一個(gè)列表添加item后滾動(dòng)顯示最新的添加的item
回到頂部(#)
滾動(dòng)到指定位置(#xxx)
6、瀏覽器兼容性

二、實(shí)際運(yùn)用

如圖所示一個(gè)類(lèi)似微信一樣的electron項(xiàng)目,這個(gè)是消息列表,然后有消息過(guò)來(lái)的時(shí)候,就是右下角托盤(pán)消息提醒的時(shí)候,點(diǎn)擊消息提示中的某一項(xiàng),然后就打開(kāi)這個(gè)頁(yè)面,定位到選中的某一個(gè),再右邊顯示詳細(xì)信息
先說(shuō)下具體思路:在Vue 3中,可以使用v-for指令的ref屬性來(lái)綁定每個(gè)列表項(xiàng)的引用。然后,使用computed屬性來(lái)獲取要滾動(dòng)到的元素,并使用scrollIntoView方法將其滾動(dòng)到可見(jiàn)區(qū)域。
以下是在Vue 3中使用v-for和computed實(shí)現(xiàn)根據(jù)列表的索引定位到某一行的示例:
<template>
<div>
<div v-for="(item, index) in list" :key="index" :ref="'listItem-' + index">{{ item }}</div>
</div>
</template>
<script>
import { computed, ref } from 'vue';
export default {
setup() {
const list = ref(['Item 1', 'Item 2', 'Item 3', 'Item 4', 'Item 5']);
const activeIndex = ref(null);
// 計(jì)算要滾動(dòng)到的元素
const activeElement = computed(() => {
if (activeIndex.value !== null) {
return document.querySelector(`[ref="listItem-${activeIndex.value}"]`);
}
return null;
});
// 滾動(dòng)到指定的列表項(xiàng)
const scrollToIndex = (index) => {
activeIndex.value = index;
if (activeElement.value) {
activeElement.value.scrollIntoView();
}
};
return {
list,
scrollToIndex
};
}
};
</script>在上面的代碼中,使用v-for指令循環(huán)遍歷列表,并將每個(gè)列表項(xiàng)的引用綁定到ref屬性上。然后,使用computed屬性來(lái)計(jì)算要滾動(dòng)到的元素。在scrollToIndex方法中,使用activeIndex來(lái)存儲(chǔ)要滾動(dòng)到的元素的索引,并使用activeElement計(jì)算出要滾動(dòng)到的元素。最后,使用scrollIntoView方法將該元素滾動(dòng)到可見(jiàn)區(qū)域。
在組件中觸發(fā)scrollToIndex方法,可以在需要滾動(dòng)到指定列表項(xiàng)時(shí)調(diào)用該方法。例如,可以在按鈕的點(diǎn)擊事件處理程序中調(diào)用scrollToIndex方法:
<button @click="scrollToIndex(3)">Scroll to Index 3</button>
在上面的代碼中,單擊按鈕將調(diào)用scrollToIndex方法,并將3作為參數(shù)傳遞給該方法,以滾動(dòng)到索引為3的列表項(xiàng)。
再看下我具體寫(xiě)的:

watch(clickId, async() => {
// console.log('clickId changed from', oldValue, 'to', newValue)
// eslint-disable-next-line
const data = await window.app.windowGetData(store.userBaseInfo.username + '.data.warn')
let code = 0
const index = data.findIndex((item:any) => (
item.configId === clickId.value
))
data.forEach((item:any) => {
if (item.configId === clickId.value) {
code = Number(item.code)
}
})
if (index !== -1) {
itemClick(index, code)
scrollToIndex() // 點(diǎn)擊托盤(pán)消息的時(shí)候觸發(fā)這里
}
})
// 計(jì)算要滾動(dòng)到的元素
const activeElement = computed(() => {
if (activeIndex.value) {
return document.getElementById(`listItem-${ activeIndex.value }`)
}
return null
})
// 滾動(dòng)到指定的列表項(xiàng)
const scrollToIndex = () => {
if (activeElement.value) {
activeElement.value.scrollIntoView(false)
}
}
完事!
總結(jié)
到此這篇關(guān)于Vue中scrollIntoView()方法詳解與實(shí)際運(yùn)用的文章就介紹到這了,更多相關(guān)Vue scrollIntoView()方法詳解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue項(xiàng)目中的webpack-dev-sever配置方法
下面小編就為大家分享一篇vue項(xiàng)目中的webpack-dev-sever配置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
Vue-router如何實(shí)現(xiàn)路由懶加載
在現(xiàn)代前端開(kāi)發(fā)中,Vue.js憑借其輕量級(jí)和易用性,成為了很多開(kāi)發(fā)者的首選框架,本文將結(jié)合實(shí)際案例,詳細(xì)講解Vue-Router路由懶加載的用法,需要的可以參考下2024-11-11
vue 使用Jade模板寫(xiě)html,stylus寫(xiě)css的方法
這篇文章主要介紹了vue 使用Jade模板寫(xiě)html,stylus寫(xiě)css的方法,文中還給大家提到了使用jade注意事項(xiàng),需要的朋友可以參考下2018-02-02
vue中echarts點(diǎn)擊事件點(diǎn)擊一次多次觸發(fā)問(wèn)題
這篇文章主要介紹了vue中echarts點(diǎn)擊事件點(diǎn)擊一次多次觸發(fā)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
vue后臺(tái)系統(tǒng)管理項(xiàng)目之角色權(quán)限分配管理功能(示例詳解)
這篇文章主要介紹了vue后臺(tái)系統(tǒng)管理項(xiàng)目-角色權(quán)限分配管理功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09

