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

vue封裝實(shí)現(xiàn)自動(dòng)循環(huán)滾動(dòng)的列表

 更新時(shí)間:2023年09月14日 11:15:59   作者:HXY999  
在做數(shù)據(jù)大屏開發(fā)的過(guò)程中,經(jīng)常出現(xiàn)需要對(duì)列表進(jìn)行自動(dòng)滾動(dòng)的需求,所以本文就來(lái)為大家介紹一下如何利用vue封裝一個(gè)自動(dòng)循環(huán)滾動(dòng)的列表吧

前言

在做數(shù)據(jù)大屏開發(fā)的過(guò)程中,經(jīng)常出現(xiàn)需要對(duì)列表進(jìn)行自動(dòng)滾動(dòng)的需求,為了個(gè)性化的實(shí)現(xiàn)各種需求,就封裝了一個(gè)函數(shù)方法

解決方案

  • 生成一個(gè)父元素,并給其固定的高度,通過(guò)$refs獲取并賦值給container變量
  • 獲取一些關(guān)于container和其子元素的信息,如父容器高度(parentHeight)、滾動(dòng)高度(scrollHeight)、第一個(gè)子元素的高度(childHeight)、子元素?cái)?shù)量(childCount)、最大高度(maxHeight)、當(dāng)前滾動(dòng)位置(toHeight)和當(dāng)前子元素索引(current),并初始化一個(gè)名為timer的計(jì)時(shí)器。
  • 定義一個(gè)名為scrollCore的函數(shù),該函數(shù)用于實(shí)現(xiàn)滾動(dòng)效果。
  • scrollCore函數(shù)中檢查如果scrollHeight大于parentHeight,則創(chuàng)建一個(gè)定時(shí)器,以便每隔一段時(shí)間執(zhí)行一次滾動(dòng)操作。
  • 在定時(shí)器中,scrollCore函數(shù)中逐漸增加容器的scrollTop屬性,從而實(shí)現(xiàn)滾動(dòng)效果。

一、勻速自動(dòng)滾動(dòng),并實(shí)現(xiàn)方法可對(duì)多個(gè)列表復(fù)用

思路:通過(guò)對(duì)ref的命名,來(lái)實(shí)現(xiàn)在方法中使用for循環(huán)來(lái)對(duì)多個(gè)列表生效

<template>
<div>
    <ul class="shiJianGaoJingContent_right" ref="scroll0">
        <li class="gaojing_info_list" v-for="(item, index) in scrollInfoList" :key="index">
        </li>
    </ul> 
</div>
</template>
<script>
export default {
  data() {
    return {
      scrollInfoList:[],
    };
  },
  methods: {
  // 列表自動(dòng)滾動(dòng)
    scrollFn() {
      let dataList = [];
      for (let i = 0; i < 1; i++) {
        let container = this.$refs["scroll" + i];
        let parentHeight = container.offsetHeight || 0;
        let scrollHeight = container.scrollHeight;
        let childHeight = container.firstChild.offsetHeight;
        let childCount = container.childNodes.length;
        let maxHeight = childHeight * childCount;
        let toHeight = container.scrollTop;
        let current = 0;
        dataList.push({
          parentHeight,
          scrollHeight,
          childHeight,
          childCount,
          maxHeight,
          toHeight,
          current,
          timer: null,
          timerMouseWheel: null,
        });
        function scrollCore() {
          {
            if (scrollHeight > parentHeight) {
              dataList[i].timer = setInterval(() => {
                let scrollStep = 1; // 每幀滾動(dòng)的步長(zhǎng),可以適當(dāng)調(diào)整
                if (container.scrollTop + parentHeight + 5 >= scrollHeight) {
                  // 如果滾動(dòng)到底部,則將滾動(dòng)位置重置為0
                  container.scrollTop = 0;
                  dataList[i].toHeight = 0;
                  dataList[i].current = 0;
                } else {
                  if (container.scrollTop < dataList[i].toHeight + dataList[i].childHeight) {
                    // 如果尚未滾動(dòng)到目標(biāo)位置,則逐幀更新滾動(dòng)位置
                    container.scrollTop += scrollStep;
                  } else {
                    // 已滾動(dòng)到目標(biāo)位置,更新當(dāng)前子項(xiàng)索引和子項(xiàng)高度
                    dataList[i].current = (dataList[i].current + 1) % dataList[i].childCount;
                    dataList[i].childHeight = container.childNodes[dataList[i].current].offsetHeight;
                    dataList[i].toHeight = container.scrollTop;
                  }
                }
              }, 2000 / 60); // 設(shè)置每秒更新60次,可根據(jù)需求調(diào)整
            }
          }
        }
        scrollCore()
      }
    },
  },
  mounted() {},
};
</script>

注:該方法在自動(dòng)滾動(dòng)到底部后會(huì)返回到頂部,循環(huán)滾動(dòng)需要更改邏輯,在下方有循環(huán)的方法。

二、如何暫時(shí)關(guān)閉自動(dòng)滾動(dòng)

當(dāng)我們想自己通過(guò)鼠標(biāo)滾輪滾動(dòng)該列表時(shí),使該列表的自動(dòng)滾動(dòng)暫停,我們可以添加了一個(gè)名為mousewheel的事件監(jiān)聽器,以便在鼠標(biāo)滾輪滾動(dòng)時(shí)執(zhí)行以下操作:

  • 清除之前的定時(shí)器dataList[i].timerdataList[i].timerMouseWheel。
  • 更新dataList[i].toHeight為當(dāng)前滾動(dòng)位置,并將滾動(dòng)位置設(shè)置為相同的值。
  • 設(shè)置一個(gè)新的定時(shí)器dataList[i].timerMouseWheel,在一段時(shí)間后重新調(diào)用scrollCore函數(shù),以恢復(fù)自動(dòng)滾動(dòng)效果。
 container.addEventListener("mousewheel", () => {
          this.$nextTick(() => {
            clearInterval(dataList[i].timer);
            clearInterval(dataList[i].timerMouseWheel);
            dataList[i].toHeight = container.scrollTop;
            container.scrollTop = container.scrollTop;
            dataList[i].timerMouseWheel = setTimeout(() => {
              scrollCore()
            }, 3000)
          });
        });

三、如何徹底關(guān)閉自動(dòng)滾動(dòng)

在上面的方法中會(huì)一直無(wú)限的滾動(dòng)下去,那么我們?nèi)绻胪O戮唧w看某一項(xiàng)要把自動(dòng)滾動(dòng)關(guān)閉掉呢,我們可以通過(guò)將關(guān)閉方法寫在container的某個(gè)事件中,并將該事件派發(fā)給container來(lái)實(shí)現(xiàn)

// 監(jiān)聽關(guān)閉自動(dòng)滾動(dòng)的事件
container.addEventListener("closeScroll", () => {
          this.$nextTick(() => {
            clearInterval(dataList[i].timer);
            clearInterval(dataList[i].timerMouseWheel);
            toHeight = container.scrollTop;
            container.scrollTop = container.scrollTop;
          });
        });
// 完整代碼
// 關(guān)閉列表自動(dòng)滾動(dòng)
    closeListScroll(container) {
      // 創(chuàng)建一個(gè)新的 自定義 事件
      const closeScroll = new Event("closeScroll");
      container.dispatchEvent(closeScroll)
    },
// 列表自動(dòng)滾動(dòng)
    scrollFn() {
      let dataList = [];
      for (let i = 0; i < 1; i++) {
        let container = this.$refs["scroll" + i];
        let parentHeight = container.offsetHeight || 0;
        let scrollHeight = container.scrollHeight;
        let childHeight = container.firstChild.offsetHeight;
        let childCount = container.childNodes.length;
        let maxHeight = childHeight * childCount;
        let toHeight = container.scrollTop;
        let current = 0;
        dataList.push({
          parentHeight,
          scrollHeight,
          childHeight,
          childCount,
          maxHeight,
          toHeight,
          current,
          timer: null,
          timerMouseWheel: null,
        });
        function scrollCore() {
          {
            if (scrollHeight > parentHeight) {
              dataList[i].timer = setInterval(() => {
                let scrollStep = 1; // 每幀滾動(dòng)的步長(zhǎng),可以適當(dāng)調(diào)整
                if (container.scrollTop + parentHeight + 5 >= scrollHeight) {
                  // 如果滾動(dòng)到底部,則將滾動(dòng)位置重置為0
                  container.scrollTop = 0;
                  dataList[i].toHeight = 0;
                  dataList[i].current = 0;
                } else {
                  if (container.scrollTop < dataList[i].toHeight + dataList[i].childHeight) {
                    // 如果尚未滾動(dòng)到目標(biāo)位置,則逐幀更新滾動(dòng)位置
                    container.scrollTop += scrollStep;
                  } else {
                    // 已滾動(dòng)到目標(biāo)位置,更新當(dāng)前子項(xiàng)索引和子項(xiàng)高度
                    dataList[i].current = (dataList[i].current + 1) % dataList[i].childCount;
                    dataList[i].childHeight = container.childNodes[dataList[i].current].offsetHeight;
                    dataList[i].toHeight = container.scrollTop;
                  }
                }
              }, 2000 / 60); // 設(shè)置每秒更新60次,可根據(jù)需求調(diào)整
            }
          }
        }
        scrollCore()
        container.addEventListener("mousewheel", () => {
          this.$nextTick(() => {
            clearInterval(dataList[i].timer);
            clearInterval(dataList[i].timerMouseWheel);
            dataList[i].toHeight = container.scrollTop;
            container.scrollTop = container.scrollTop;
            dataList[i].timerMouseWheel = setTimeout(() => {
              scrollCore()
            }, 3000)
          });
        });
        container.addEventListener("closeScroll", () => {
          this.$nextTick(() => {
            clearInterval(dataList[i].timer);
            clearInterval(dataList[i].timerMouseWheel);
            toHeight = container.scrollTop;
            container.scrollTop = container.scrollTop;
          });
        });
      }
    },

通過(guò)如上代碼 我們就可以通過(guò)調(diào)用closeListScroll()方法來(lái)關(guān)閉列表自動(dòng)滾動(dòng),如我們想要關(guān)閉ref=scroll0列表的自動(dòng)滾動(dòng)

// 示例 關(guān)閉ref=scroll0列表的自動(dòng)滾動(dòng)
// 某個(gè)方法中
clickSomeBtn(){
    ... //其他邏輯
    this.closeListScroll(this.$refs["scroll0"])
}

四、如何使自動(dòng)滾動(dòng)無(wú)限循環(huán),使其頭尾相連

思路:將一份數(shù)據(jù)復(fù)制為兩份,在滾動(dòng)到第二份與第一份重合的時(shí)候 立刻將滾動(dòng)高度歸位,這樣從視覺效果上來(lái)看,就是無(wú)限滾動(dòng)的效果 要實(shí)現(xiàn)這個(gè)效果,首先是我們需要將一份數(shù)據(jù)變?yōu)閮煞荩顬楹?jiǎn)單的實(shí)現(xiàn)思路為直接將數(shù)據(jù)變?yōu)閮煞?/p>

<li class="gaojing_info_list" v-for="(item, index) in [...scrollInfoList,...scrollInfoList]" :key="index">

但是這樣的話,我們需要對(duì)所有的列表都進(jìn)行更改,容易遺漏,不符合封裝思路
于是我就想著通過(guò)DOM方法直接在封裝函數(shù)中進(jìn)行操作,實(shí)現(xiàn)思路為

  • 使用DOM方法獲取container的所有子元素,并將它們存儲(chǔ)在名為children的變量中。
  • 創(chuàng)建一個(gè)文檔片段(Document Fragment)并將子元素逐個(gè)克隆并添加到文檔片段中。
  • 一次性將文檔片段添加回container中,以提高性能。 當(dāng)我們實(shí)現(xiàn)了克隆兩份數(shù)據(jù)后,通過(guò)對(duì)container.scrollTop >= scrollHeight / 2的判斷,來(lái)得到我們已經(jīng)來(lái)到了第二頁(yè)與初始位置重復(fù)的位置,在這個(gè)時(shí)候?qū)L動(dòng)位置重置,在視覺上就會(huì)實(shí)現(xiàn)首尾相連無(wú)限滾動(dòng)的效果
// 列表自動(dòng)循環(huán)滾動(dòng)
scrollFn() {
  let dataList = [];
  for (let i = 0; i < 1; i++) {
    let container = this.$refs["scroll" + i];
    console.log(container);
    // 使用 DOM 方法獲取所有子元素
    let children = container.children;
    // 創(chuàng)建一個(gè)文檔片段
    let fragment = document.createDocumentFragment();
    // 將子元素逐個(gè)重新插入到容器中
    for (let ind = 0; ind < children.length; ind++) {
      const child = children[ind].cloneNode(true);
      console.log(child, "child");
      fragment.appendChild(child);
    }
    // 一次性將文檔片段添加回容器中
    this.$refs["scroll" + i].appendChild(fragment);
    let parentHeight = container.offsetHeight || 0;
    let scrollHeight = container.scrollHeight;
    let childHeight = container.firstChild.offsetHeight;
    let childCount = container.childNodes.length;
    let maxHeight = childHeight * childCount;
    let toHeight = container.scrollTop;
    let current = 0;
    dataList.push({
      parentHeight,
      scrollHeight,
      childHeight,
      childCount,
      maxHeight,
      toHeight,
      current,
      timer: null,
    });
    function scrollCore() {
      if (scrollHeight > parentHeight) {
        dataList[i].timer = setInterval(() => {
          let scrollStep = 1; // 每幀滾動(dòng)的步長(zhǎng),可以適當(dāng)調(diào)整
          if (container.scrollTop >= scrollHeight / 2) {
            // 滾動(dòng)到與第一行重復(fù)的位置后 重置
            container.scrollTop = 0;
            dataList[i].toHeight = 0;
            dataList[i].current = 0;
          } else {
            if (
              container.scrollTop <
              dataList[i].toHeight + dataList[i].childHeight
            ) {
              // 如果尚未滾動(dòng)到目標(biāo)位置,則逐幀更新滾動(dòng)位置
              container.scrollTop += scrollStep;
            } else {
              // 已滾動(dòng)到目標(biāo)位置,更新當(dāng)前子項(xiàng)索引和子項(xiàng)高度
              dataList[i].current =
                (dataList[i].current + 1) % dataList[i].childCount;
              dataList[i].childHeight =
                container.childNodes[dataList[i].current].offsetHeight;
              dataList[i].toHeight = container.scrollTop;
            }
          }
        }, 2000 / 60); // 設(shè)置每秒更新60次,可根據(jù)需求調(diào)整
      }
    }
    scrollCore();
    container.addEventListener("mousewheel", () => {
      this.$nextTick(() => {
        clearInterval(dataList[i].timer);
        clearInterval(dataList[i].timerMouseWheel);
        dataList[i].toHeight = container.scrollTop;
        container.scrollTop = container.scrollTop;
        dataList[i].timerMouseWheel = setTimeout(() => {
          scrollCore();
        }, 3000);
      });
    });
     container.addEventListener("closeScroll", () => {
          this.$nextTick(() => {
            clearInterval(dataList[i].timer);
            clearInterval(dataList[i].timerMouseWheel);
            toHeight = container.scrollTop;
            container.scrollTop = container.scrollTop;
          });
        });
  }
}

以上就是vue封裝實(shí)現(xiàn)自動(dòng)循環(huán)滾動(dòng)的列表的詳細(xì)內(nèi)容,更多關(guān)于vue循環(huán)滾動(dòng)列表的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue?結(jié)合Sortablejs實(shí)現(xiàn)table行排序功能

    Vue?結(jié)合Sortablejs實(shí)現(xiàn)table行排序功能

    在一個(gè)列表展示頁(yè)面上,使用了表格組件,原有組件本身不支持拖拽功能,需求要求在列表的基礎(chǔ)上支持行拖拽排序,因此引入了www.sortablejs.com插件,接下來(lái)通過(guò)本文給大家講解Vue?結(jié)合Sortablejs實(shí)現(xiàn)table行排序功能,需要的朋友可以參考下
    2022-10-10
  • vue父子組件傳值不能實(shí)時(shí)更新的解決方法

    vue父子組件傳值不能實(shí)時(shí)更新的解決方法

    Vue是一個(gè)以數(shù)據(jù)驅(qū)動(dòng)、組件化的前端框架,其中組件化是Vue中較為重要的概念之一,組件之間的通信則成為Vue中較為普遍的需求,下面這篇文章主要給大家介紹了關(guān)于vue父子組件傳值不能實(shí)時(shí)更新的解決方法,需要的朋友可以參考下
    2023-05-05
  • 在Vue中使用CSS3實(shí)現(xiàn)內(nèi)容無(wú)縫滾動(dòng)的示例代碼

    在Vue中使用CSS3實(shí)現(xiàn)內(nèi)容無(wú)縫滾動(dòng)的示例代碼

    這篇文章主要介紹了在Vue中使用CSS3實(shí)現(xiàn)內(nèi)容無(wú)縫滾動(dòng)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • 詳解vue移動(dòng)端項(xiàng)目的適配(以mint-ui為例)

    詳解vue移動(dòng)端項(xiàng)目的適配(以mint-ui為例)

    這篇文章主要介紹了詳解vue移動(dòng)端項(xiàng)目的適配(以mint-ui為例),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • Vue組件的使用及個(gè)人理解與介紹

    Vue組件的使用及個(gè)人理解與介紹

    本文介紹了VUE中組件的基本使用以及個(gè)人對(duì)VUE組件的理解,希望能幫助到大家
    2019-02-02
  • Vue監(jiān)聽頁(yè)面刷新和關(guān)閉功能

    Vue監(jiān)聽頁(yè)面刷新和關(guān)閉功能

    我在做項(xiàng)目的時(shí)候,有一個(gè)需求,在離開(跳轉(zhuǎn)或者關(guān)閉)購(gòu)物車頁(yè)面或者刷新購(gòu)物車頁(yè)面的時(shí)候向服務(wù)器提交一次購(gòu)物車商品數(shù)量的變化。這篇文章主要介紹了vue監(jiān)聽頁(yè)面刷新和關(guān)閉功能,需要的朋友可以參考下
    2019-06-06
  • Vuex中actions優(yōu)雅處理接口請(qǐng)求的方法

    Vuex中actions優(yōu)雅處理接口請(qǐng)求的方法

    在項(xiàng)目開發(fā)中,如果使用到了 vuex,通常我會(huì)將所有的接口請(qǐng)求單獨(dú)用一個(gè)文件管理,這篇文章主要介紹了Vuex中actions如何優(yōu)雅處理接口請(qǐng)求,業(yè)務(wù)邏輯寫在 actions 中,本文給大家分享完整流程需要的朋友可以參考下
    2022-11-11
  • 修改vue+webpack run build的路徑方法

    修改vue+webpack run build的路徑方法

    今天小編就為大家分享一篇修改vue+webpack run build的路徑方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • Vue組件通信中非父子組件傳值知識(shí)點(diǎn)總結(jié)

    Vue組件通信中非父子組件傳值知識(shí)點(diǎn)總結(jié)

    在本篇文章里小編給大家整理的是關(guān)于Vue組件通信中非父子組件傳值知識(shí)點(diǎn)總結(jié),有興趣的朋友們學(xué)習(xí)下。
    2019-12-12
  • vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)

    vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)

    這篇文章主要為大家介紹了vue?parseHTML源碼解析hars?end?comment鉤子函數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07

最新評(píng)論