中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue讀取HTMLCollection列表的length為0問題怎么解決

發布時間:2022-06-06 10:36:27 來源:億速云 閱讀:508 作者:iii 欄目:開發技術

這篇“Vue讀取HTMLCollection列表的length為0問題怎么解決”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Vue讀取HTMLCollection列表的length為0問題怎么解決”文章吧。

讀取HTMLCollection列表的length為0

在計算better-scroll右側列表滾動高度的時候,發現列表的length為0

Vue讀取HTMLCollection列表的length為0問題怎么解決

原因

上網查閱發現問題可能是由于mounted 不會承諾所有的子組件也都一起被掛載。

這個時候dom元素還有沒掛載完畢。如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 替換掉 mounted:

mounted () {
      this.$nextTick(() => {
      this._initScroll(), this._calculateHeight();
    });  },

但是不清楚為什么使用了這個方法后獲取的length依舊為0,

就在_calculateHeight()方法上加了個定時器,等到完全渲染完成時再獲取高度(這種問題可能會出現bug,不知道頁面什么時候渲染完畢):

_calculateHeight () {
      setTimeout(() => {
        let foodList = this.$refs.right.getElementsByClassName('food-list-hook');
        let height = 0;
        this.listHeight.push(height);
        for (var i = 0; i < foodList.length; i++) {
          let item = foodList[i];
          height += item.clientHeight;
          this.listHeight.push(height);
        }
      }, 200)
    },

無法讀取HTMLCollection列表的length解決

問題

在學習餓了么實踐項目時候發現一個問題,

在mounted階段,獲取Element對象,console.log()可以讀取出列表,而卻無法讀出它的length 

如下

      let foodList = this.$refs.menuWrapper.getElementsByClassName('calculate-content')
      let height = 0
      console.log(foodList)
      console.log(foodList.length)
      for (var i = 0; i < foodList.length; i++) {
        height += foodList[i].clientHeight
        this.scrollYList.push(height)
      }

Vue讀取HTMLCollection列表的length為0問題怎么解決

原因

以下出自官方文檔

  • mounted

  • 類型:Function

  • 詳細:

  • el 被新創建的 vm.$el 替換,并掛載到實例上去之后調用該鉤子。如果 root 實例掛載了一個文檔內元素,當 mounted 被調用時 vm.$el 也在文檔內。

注意 mounted 不會承諾所有的子組件也都一起被掛載。如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 替換掉 mounted:

mounted: function () {
this.$nextTick(function () {
// Code that will run only after the
// entire view has been rendered
})
}

該鉤子在服務器端渲染期間不被調用。

看完以上文檔介紹,可以知道在mounted階段,mounted 不會承諾所有的子組件也都一起被掛載,所以在此階段,dom結構還沒加載完,js就執行了  

解決方案

1.使用官方文檔說明(如果你希望等到整個視圖都渲染完畢,可以用 vm.$nextTick 確保渲染完成后再獲取數據。

重要的是理解執行順序,異步調用的話可以使用Promise保證執行順序

踩到的一個坑:

有文章說可以在updated階段執行,這時可以取到渲染完畢后的List

updated:由于數據更改導致的虛擬 DOM 重新渲染和打補丁,在這之后會調用該鉤子

就是說,在使用better-scroll滾動時,會觸發updated,使得scrollYList不斷被推入數據,然后導致我用這個的時候,整個瀏

覽器崩潰了,很是尷尬,哈哈哈,所以我感覺updated執行這個解決方案,不大適合解決這類問題

以上就是關于“Vue讀取HTMLCollection列表的length為0問題怎么解決”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

三穗县| 南宫市| 东阳市| 延寿县| 宜兰县| 徐闻县| 思茅市| 桑植县| 凤阳县| 合阳县| 鄂尔多斯市| 侯马市| 安化县| 博客| 临沂市| 松潘县| 东辽县| 建瓯市| 兴义市| 宁南县| 鲁甸县| 江口县| 富源县| 临桂县| 襄城县| 安宁市| 章丘市| 浮梁县| 信阳市| 汽车| 靖远县| 双辽市| 宁明县| 平阴县| 长顺县| 广平县| 揭阳市| 双辽市| 诸暨市| 汤阴县| 区。|