您好,登錄后才能下訂單哦!
這篇文章主要介紹“vue this.$refs.xxx獲取dom的注意事項是什么”,在日常操作中,相信很多人在vue this.$refs.xxx獲取dom的注意事項是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”vue this.$refs.xxx獲取dom的注意事項是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
vue
項目:
v-for
渲染的元素,如果內容超過一行,則右側展示一個"更多"按鈕,點擊“更多”按鈕后,再展示全部的數據。
在上家公司的時候,我也遇到過類似的要求,但是當時水平菜的底氣硬,直接一個不會,愣是把需求改為了全部展示,今天遇到了這個問題,想著還是要解決一下,困難就是成長。
一行的內容高度是50px
,我只需要判斷渲染完成后,內容區的高度是否超過50px
即可。
于是:html
部分代碼:
<div class="searchWrap"> <div class="searchItem" v-for="(tag, tagIndex) in pinPaiList" :key="tagIndex"> <div class="searchLeft">{{ tag.tagSortTitle }}</div> <div class="searchList" :ref="'tagParent' + tagIndex"> <div v-for="(p, pIndex) in tag.items" :key="pIndex" class="listCls"> <span @click="selectPP(tagIndex, pIndex)" :class="{ active: p.checked }">{{ p.value | filterStr }}</span></div></div> <div class="searchMore"> <div> <div class="el-icon-arrow-down" v-if="tag.moreFlag" @click="moreData(tagIndex)">更多</div> <div class="el-icon-circle-check" v-if="tag.selectMore" @click="sureSearch(tagIndex)" :class="{ active: tag.selectMore }" >確定</div> <div @click="changeType(tagIndex)" :class="{ active: tag.selectMore }" class="el-icon-circle-plus-outline">{{ !tag.selectMore ? "單選" : "多選" }} </div> </div> </div> </div> </div>
上面代碼的重點在于,我要在v-for
渲染的dom
元素上綁定ref
,動態綁定屬性的方式跟其他的動態綁定一致:
:ref="'tagParent' + tagIndex"
tag.moreFlag
就是判斷是否要展示更多
按鈕的關鍵,這個是根據dom
元素的高度來判斷的。
vue
項目中獲取dom
元素的高度——this.$refs.xxx
vue
項目中獲取dom
元素的高度可以通過this.$refs.xxx
的方式來處理:
但是我在使用的過程中,this.$refs.xxx
的方式獲取dom
,經常會出現undefined
,也有少數情況是可以獲取到的。
具體原因就是:如果是用v-if
或者v-for
渲染的dom
元素,是不能直接使用this.$refs.xxx
的方式來獲取dom
的,即便是放在this.$nextTick
里面也是不行的。
需要在獲取到數據之后,再通過this.$nextTick
的方式來處理:
我這邊的處理方法如下:
... //此處的this.pinPaiList是從上面的接口中獲取到的數據,需要循環遍歷,依次判斷高度 this.pinPaiList && this.pinPaiList.forEach((p, pIndex) => { this.$nextTick(() => { //一定要注意通過this.$refs.xxx的方式獲取到的dom要取index為0的一項,然后獲取高度通過clientHight來獲取,如果不是v-if或者v-for渲染的dom,則不需要加這個0。 var height = this.$refs[`tagParent${pIndex}`][0].clientHeight; if (height > 50) { this.pinPaiList[pIndex].moreFlag = true; //如果判斷出來某一項的高度超出一行,則延遲將此行的高度設置為一行,進而展示更多按鈕,點擊更多按鈕時將height改為auto即可 setTimeout(() => { this.$refs[`tagParent${pIndex}`][0].style.height = "35px"; }, 0); } else { this.pinPaiList[pIndex].moreFlag = false; } this.$set(this.pinPaiList, pIndex, this.pinPaiList[pIndex]); }); }); ... //點擊更多按鈕 moreData(index) { this.pinPaiList[index].moreFlag = false; this.$set(this.pinPaiList, index, this.pinPaiList[index]);//這個是vue2的缺陷,數據改變視圖不渲染的解決方案 setTimeout(() => { this.$refs[`tagParent${index}`][0].style.height = "auto"; }, 0); }
到此,關于“vue this.$refs.xxx獲取dom的注意事項是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。