欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue中scrollIntoView()方法詳解與實(shí)際運(yùn)用舉例

 更新時(shí)間:2023年12月20日 10:31:41   作者:老電影故事  
這篇文章主要給大家介紹了關(guān)于Vue中scrollIntoView()方法詳解與實(shí)際運(yùn)用舉例的相關(guān)資料,該scrollIntoView()方法將調(diào)用它的元素滾動(dòng)到瀏覽器窗口的可見(jiàn)區(qū)域,需要的朋友可以參考下

前言

因?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配置方法

    下面小編就為大家分享一篇vue項(xiàng)目中的webpack-dev-sever配置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • Vue-router如何實(shí)現(xiàn)路由懶加載

    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的方法

    這篇文章主要介紹了vue 使用Jade模板寫(xiě)html,stylus寫(xiě)css的方法,文中還給大家提到了使用jade注意事項(xiàng),需要的朋友可以參考下
    2018-02-02
  • Vue?element樹(shù)形控件添加虛線詳解

    Vue?element樹(shù)形控件添加虛線詳解

    這篇文章主要為大家介紹了Vue?element樹(shù)形控件添加虛線,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助<BR>
    2021-11-11
  • Vue執(zhí)行流程及渲染示例解析

    Vue執(zhí)行流程及渲染示例解析

    這篇文章主要為大家介紹了Vue執(zhí)行流程及渲染解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • vue中echarts點(diǎn)擊事件點(diǎn)擊一次多次觸發(fā)問(wèn)題

    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 組件之間傳值

    深入理解Vue 組件之間傳值

    這篇文章較詳細(xì)的給大家介紹了vue組件之間傳值的方法,在 Vue 中,可以使用props向子組件傳遞數(shù)據(jù)。具體傳遞方法大家跟隨腳本之家小編一起看看吧
    2018-08-08
  • vue截取視頻第一幀的圖片問(wèn)題

    vue截取視頻第一幀的圖片問(wèn)題

    這篇文章主要介紹了vue截取視頻第一幀的圖片問(wèn)題,基本就是用cavas進(jìn)行繪制,解決一下跨域問(wèn)題,截視頻第一幀,然后根據(jù)視頻原本的寬高進(jìn)行繪制,最后轉(zhuǎn)一下圖片格式即可,需要的朋友可以參考下
    2022-11-11
  • vue中的路由攔截器的作用詳解

    vue中的路由攔截器的作用詳解

    在Vue中,路由攔截器主要用于在導(dǎo)航到某個(gè)路由前或者離開(kāi)某個(gè)路由時(shí)進(jìn)行攔截和處理,下面給大家介紹vue中的路由攔截器的作用,感興趣的朋友一起看看吧
    2024-07-07
  • vue后臺(tái)系統(tǒng)管理項(xiàng)目之角色權(quán)限分配管理功能(示例詳解)

    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

最新評(píng)論