Vue 無法讀取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)
      }


原因:

以下出自官方文檔

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執行這個解決方案,不大適合解決這類問題

 

本文來源於:https://blog.csdn.net/weixin_41602509/article/details/86661758

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM