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

Vue 讀取HTMLCollection列表的length為0問(wèn)題

 更新時(shí)間:2022年06月02日 16:42:38   作者:小丸子yeah~  
這篇文章主要介紹了Vue 讀取HTMLCollection列表的length為0問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

讀取HTMLCollection列表的length為0

在計(jì)算better-scroll右側(cè)列表滾動(dòng)高度的時(shí)候,發(fā)現(xiàn)列表的length為0

在這里插入圖片描述

原因

上網(wǎng)查閱發(fā)現(xiàn)問(wèn)題可能是由于mounted 不會(huì)承諾所有的子組件也都一起被掛載。

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

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

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

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

_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)
? ? },

無(wú)法讀取HTMLCollection列表的length解決

問(wèn)題

在學(xué)習(xí)餓了么實(shí)踐項(xiàng)目時(shí)候發(fā)現(xiàn)一個(gè)問(wèn)題,

在mounted階段,獲取Element對(duì)象,console.log()可以讀取出列表,而卻無(wú)法讀出它的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
  • 類(lèi)型:Function
  • 詳細(xì):
  • el 被新創(chuàng)建的 vm.$el 替換,并掛載到實(shí)例上去之后調(diào)用該鉤子。如果 root 實(shí)例掛載了一個(gè)文檔內(nèi)元素,當(dāng) mounted 被調(diào)用時(shí) vm.$el 也在文檔內(nèi)。

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

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

該鉤子在服務(wù)器端渲染期間不被調(diào)用。

看完以上文檔介紹,可以知道在mounted階段,mounted 不會(huì)承諾所有的子組件也都一起被掛載,所以在此階段,dom結(jié)構(gòu)還沒(méi)加載完,js就執(zhí)行了  

解決方案

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

重要的是理解執(zhí)行順序,異步調(diào)用的話可以使用Promise保證執(zhí)行順序

踩到的一個(gè)坑:

有文章說(shuō)可以在updated階段執(zhí)行,這時(shí)可以取到渲染完畢后的List

updated:由于數(shù)據(jù)更改導(dǎo)致的虛擬 DOM 重新渲染和打補(bǔ)丁,在這之后會(huì)調(diào)用該鉤子

就是說(shuō),在使用better-scroll滾動(dòng)時(shí),會(huì)觸發(fā)updated,使得scrollYList不斷被推入數(shù)據(jù),然后導(dǎo)致我用這個(gè)的時(shí)候,整個(gè)瀏

覽器崩潰了,很是尷尬,哈哈哈,所以我感覺(jué)updated執(zhí)行這個(gè)解決方案,不大適合解決這類(lèi)問(wèn)題

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決

    vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決

    這篇文章主要介紹了vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue實(shí)現(xiàn)搜索關(guān)鍵詞高亮的詳細(xì)教程

    vue實(shí)現(xiàn)搜索關(guān)鍵詞高亮的詳細(xì)教程

    這篇文章主要為大家介紹了vue實(shí)現(xiàn)搜索關(guān)鍵詞高亮的詳細(xì)教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • vue3實(shí)戰(zhàn)-axios請(qǐng)求封裝問(wèn)題(get、post、put、delete)

    vue3實(shí)戰(zhàn)-axios請(qǐng)求封裝問(wèn)題(get、post、put、delete)

    這篇文章主要介紹了vue3實(shí)戰(zhàn)-axios請(qǐng)求封裝問(wèn)題(get、post、put、delete),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue如何加載本地json數(shù)據(jù)

    vue如何加載本地json數(shù)據(jù)

    這篇文章主要介紹了vue如何加載本地json數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue項(xiàng)目中created()被調(diào)用多次的踩坑實(shí)戰(zhàn)

    vue項(xiàng)目中created()被調(diào)用多次的踩坑實(shí)戰(zhàn)

    在vue項(xiàng)目中我在created中調(diào)用了兩次get數(shù)據(jù)請(qǐng)求,所以下面這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目中created()被調(diào)用多次的踩坑實(shí)戰(zhàn),需要的朋友可以參考下
    2023-03-03
  • vue3使用ref的性能警告問(wèn)題

    vue3使用ref的性能警告問(wèn)題

    這篇文章主要介紹了vue3使用ref的性能警告問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue.js添加一些觸摸事件以及安裝fastclick的實(shí)例

    vue.js添加一些觸摸事件以及安裝fastclick的實(shí)例

    今天小編就為大家分享一篇vue.js添加一些觸摸事件以及安裝fastclick的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • vue3中的hooks總結(jié)

    vue3中的hooks總結(jié)

    這篇文章主要介紹了vue3中的hooks總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue進(jìn)行post和get請(qǐng)求實(shí)例講解

    vue進(jìn)行post和get請(qǐng)求實(shí)例講解

    這篇文章主要介紹了vue進(jìn)行post和get請(qǐng)求實(shí)例講解,違章圍繞post和get請(qǐng)求的相關(guān)資料展開(kāi)詳細(xì)內(nèi)容,具有一的的參考價(jià)值,需要的小伙伴可以參考一下
    2022-03-03
  • ruoyi-vue3 集成aj-captcha實(shí)現(xiàn)滑塊、文字點(diǎn)選驗(yàn)證碼功能

    ruoyi-vue3 集成aj-captcha實(shí)現(xiàn)滑塊、文字點(diǎn)選驗(yàn)證碼功能

    這篇文章主要介紹了 ruoyi-vue3 集成aj-captcha實(shí)現(xiàn)滑塊、文字點(diǎn)選驗(yàn)證碼,本文基于后端RuoYi-Vue 3.8.7 和 前端 RuoYi-Vue3 3.8.7,集成以AJ-Captcha文字點(diǎn)選驗(yàn)證碼為例,不需要鍵盤(pán)手動(dòng)輸入,極大優(yōu)化了傳統(tǒng)驗(yàn)證碼用戶(hù)體驗(yàn)不佳的問(wèn)題,感興趣的朋友一起看看吧
    2023-12-12

最新評(píng)論