文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

vue this.$refs.xxx获取dom的注意事项是什么

2023-07-05 17:09

关注

这篇文章主要介绍“vue this.$refs.xxx获取dom的注意事项是什么”,在日常操作中,相信很多人在vue this.$refs.xxx获取dom的注意事项是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue this.$refs.xxx获取dom的注意事项是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

今天遇到一个问题

vue项目:

v-for渲染的元素,如果内容超过一行,则右侧展示一个"更多"按钮,点击“更多”按钮后,再展示全部的数据。

vue this.$refs.xxx获取dom的注意事项是什么

vue this.$refs.xxx获取dom的注意事项是什么

在上家公司的时候,我也遇到过类似的要求,但是当时水平菜的底气硬,直接一个不会,愣是把需求改为了全部展示,今天遇到了这个问题,想着还是要解决一下,困难就是成长。

我的思路是

一行的内容高度是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元素的高度&mdash;&mdash;this.$refs.xxx

vue项目中获取dom元素的高度可以通过this.$refs.xxx的方式来处理:

但是我在使用的过程中,this.$refs.xxx的方式获取dom,经常会出现undefined,也有少数情况是可以获取到的。

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

vue this.$refs.xxx获取dom的注意事项是什么

具体的解决方法就是

需要在获取到数据之后,再通过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的注意事项是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯