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

vue?this.$refs.xxx獲取dom注意事項?v-if?v-for渲染的dom不能直接使用

 更新時間:2023年03月27日 08:58:47   作者:yehaocheng520  
這篇文章主要介紹了vue?this.$refs.xxx獲取dom注意事項?v-if?v-for渲染的dom不能直接使用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

最近被借調(diào)到其他部門寫代碼,嘿嘿,我是一塊磚,哪里需要哪里搬……

今天遇到一個問題

vue項目:

v-for渲染的元素,如果內(nèi)容超過一行,則右側(cè)展示一個"更多"按鈕,點擊“更多”按鈕后,再展示全部的數(shù)據(jù)。

在上家公司的時候,我也遇到過類似的要求,但是當(dāng)時水平菜的底氣硬,直接一個不會,愣是把需求改為了全部展示,今天遇到了這個問題,想著還是要解決一下,困難就是成長。

我的思路是

一行的內(nèi)容高度是50px,我只需要判斷渲染完成后,內(nèi)容區(qū)的高度是否超過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,動態(tài)綁定屬性的方式跟其他的動態(tài)綁定一致:

:ref="'tagParent' + tagIndex"

tag.moreFlag就是判斷是否要展示更多按鈕的關(guān)鍵,這個是根據(jù)dom元素的高度來判斷的。

vue項目中獲取dom元素的高度——this.$refs.xxx

vue項目中獲取dom元素的高度可以通過this.$refs.xxx的方式來處理:

但是我在使用的過程中,this.$refs.xxx的方式獲取dom,經(jīng)常會出現(xiàn)undefined,也有少數(shù)情況是可以獲取到的。

具體原因就是:如果是用v-if或者v-for渲染的dom元素,是不能直接使用this.$refs.xxx的方式來獲取dom的,即便是放在this.$nextTick里面也是不行的。

具體原因可以查看下面的鏈接:

http://www.dbjr.com.cn/article/279018.htm

具體的解決方法就是

需要在獲取到數(shù)據(jù)之后,再通過this.$nextTick的方式來處理:

我這邊的處理方法如下:

...
//此處的this.pinPaiList是從上面的接口中獲取到的數(shù)據(jù),需要循環(huán)遍歷,依次判斷高度
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;
       //如果判斷出來某一項的高度超出一行,則延遲將此行的高度設(shè)置為一行,進(jìn)而展示更多按鈕,點擊更多按鈕時將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的缺陷,數(shù)據(jù)改變視圖不渲染的解決方案
  setTimeout(() => {
    this.$refs[`tagParent${index}`][0].style.height = "auto";
  }, 0);
}

問題解決?。?!

總結(jié)

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

相關(guān)文章

  • VUE里如何修改element-ui的顯示層次與上下間隔

    VUE里如何修改element-ui的顯示層次與上下間隔

    這篇文章主要介紹了VUE里如何修改element-ui的顯示層次與上下間隔問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue 利用路由守衛(wèi)判斷是否登錄的方法

    vue 利用路由守衛(wèi)判斷是否登錄的方法

    今天小編就為大家分享一篇vue 利用路由守衛(wèi)判斷是否登錄的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue使用provide各種傳值后inject獲取undefined的問題及解決

    Vue使用provide各種傳值后inject獲取undefined的問題及解決

    這篇文章主要介紹了Vue使用provide各種傳值后inject獲取undefined的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Vue中xlsx的使用方法指南

    Vue中xlsx的使用方法指南

    這篇文章主要給大家介紹了關(guān)于Vue中xlsx的使用方法指南,有很多辦法都可以實現(xiàn),其中最簡單的還是使用插件xlsx,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • 詳解element-ui中el-select的默認(rèn)選擇項問題

    詳解element-ui中el-select的默認(rèn)選擇項問題

    這篇文章主要介紹了詳解element-ui中el-select的默認(rèn)選擇項問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 在Vue3項目中使用如何echarts問題

    在Vue3項目中使用如何echarts問題

    這篇文章主要介紹了在Vue3項目中使用如何echarts問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 淺談vue3中effect與computed的親密關(guān)系

    淺談vue3中effect與computed的親密關(guān)系

    這篇文章主要介紹了淺談vue3中effect與computed的親密關(guān)系,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Vuex模塊化和命名空間namespaced實例演示

    Vuex模塊化和命名空間namespaced實例演示

    這篇文章主要介紹了Vuex模塊化和命名空間namespaced的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-11-11
  • Vue+elementUI下拉框自定義顏色選擇器方式

    Vue+elementUI下拉框自定義顏色選擇器方式

    這篇文章主要介紹了Vue+elementUI下拉框自定義顏色選擇器方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • Iframe在Vue中的狀態(tài)保持技術(shù)

    Iframe在Vue中的狀態(tài)保持技術(shù)

    這篇文章主要為大家介紹了Iframe在Vue中的狀態(tài)保持技術(shù)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05

最新評論