關(guān)于this.$refs獲取不到dom的可能原因及解決方法
背景
搞餓了么高仿APP時(shí),使用
this.$refs.wrapper.getElementsByClassName('food-list')時(shí)獲取不到dom節(jié)點(diǎn)

正常能獲取到應(yīng)該是如下圖:

然后我又用了網(wǎng)上的方法:
this.$refs.foodList (foodList是li的dom節(jié)點(diǎn))
結(jié)果還是刷新頁面時(shí)獲取不到dom
然后我對(duì)比了網(wǎng)友訪的餓了么的源碼,下面是網(wǎng)友的

下面是我的:

然后官網(wǎng)的解釋是:因?yàn)?ref 本身是作為渲染結(jié)果被創(chuàng)建的,在初始渲染的時(shí)候你不能訪問它們 - 它們還不存在
問題解決
1.在data里面寫上一個(gè)屬性
changValue=null
如下圖:

2.在mounted鉤子函數(shù)里寫一個(gè)超時(shí)調(diào)用
setTimeout(() => {
//修改數(shù)據(jù)
this.changValue = 1;
//DOM還沒更新
this.$nextTick(() => {
//DOM現(xiàn)在更新了
this.calculateHeight();
});
},0);
使得每次掛載完成時(shí)changValue這個(gè)屬性的值獲得改變,然后調(diào)用this.$nextTick()就可以更新DOM了。
其他例子:
如果是第一次打開模態(tài)框時(shí)無法獲取this.$refs,可以讓模態(tài)框打開時(shí)修改一個(gè)data對(duì)象中的值,然后執(zhí)行this.$nextTick()就可以更新DOM了。
3.測(cè)驗(yàn)結(jié)果

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
el-form組件清除校驗(yàn)提示正確方法(前端技能提升)
el-form組件提供了表單驗(yàn)證的功能,可以通過在el-form上綁定rules屬性,并在el-form-item上設(shè)置prop屬性來進(jìn)行校驗(yàn),這篇文章主要給大家介紹了關(guān)于el-form組件清除校驗(yàn)提示正確方法(前端技能提升)的相關(guān)資料,需要的朋友可以參考下2023-12-12
vue移動(dòng)端實(shí)現(xiàn)紅包雨效果
這篇文章主要為大家詳細(xì)介紹了vue移動(dòng)端實(shí)現(xiàn)紅包雨效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07
element中TimePicker時(shí)間選擇器禁用部分時(shí)間(顯示禁用到分鐘)
這篇文章主要介紹了element中TimePicker時(shí)間選擇器禁用部分時(shí)間(顯示禁用到分鐘),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
何時(shí)/使用 Vue3 render 函數(shù)的教程詳解
這篇文章主要介紹了何時(shí)/使用 Vue3 render 函數(shù)的教程詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07

