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-12Vue-router如何實(shí)現(xiàn)路由懶加載
在現(xiàn)代前端開(kāi)發(fā)中,Vue.js憑借其輕量級(jí)和易用性,成為了很多開(kāi)發(fā)者的首選框架,本文將結(jié)合實(shí)際案例,詳細(xì)講解Vue-Router路由懶加載的用法,需要的可以參考下2024-11-11vue 使用Jade模板寫(xiě)html,stylus寫(xiě)css的方法
這篇文章主要介紹了vue 使用Jade模板寫(xiě)html,stylus寫(xiě)css的方法,文中還給大家提到了使用jade注意事項(xiàng),需要的朋友可以參考下2018-02-02vue中echarts點(diǎn)擊事件點(diǎn)擊一次多次觸發(fā)問(wèn)題
這篇文章主要介紹了vue中echarts點(diǎn)擊事件點(diǎn)擊一次多次觸發(fā)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06vue后臺(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