返回顶部
首页 > 资讯 > 精选 >vue this.$refs.xxx获取dom的注意事项是什么
  • 828
分享到

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

2023-07-05 17:07:54 828人浏览 八月长安
摘要

这篇文章主要介绍“Vue this.$refs.xxx获取dom的注意事项是什么”,在日常操作中,相信很多人在vue this.$refs.xxx获取dom的注意事项是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好

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

--结束END--

本文标题: vue this.$refs.xxx获取dom的注意事项是什么

本文链接: https://lsjlt.com/news/353443.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue this.$refs.xxx获取dom的注意事项是什么
    这篇文章主要介绍“vue this.$refs.xxx获取dom的注意事项是什么”,在日常操作中,相信很多人在vue this.$refs.xxx获取dom的注意事项是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好...
    99+
    2023-07-05
  • .height()的注意事项是什么
    这篇文章将为大家详细讲解有关.height()的注意事项是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。   .height()   描述: 获取匹配元素集合中的...
    99+
    2024-04-02
  • vue组件需要注意什么事项
    这篇文章将为大家详细讲解有关vue组件需要注意什么事项,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 vue组件要注意的事项:1、组件的tem...
    99+
    2024-04-02
  • 使用.removeProp的注意事项是什么
    本篇内容主要讲解“使用.removeProp的注意事项是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“使用.removeProp的注意事项是什么”吧!  ...
    99+
    2024-04-02
  • 使用.prop的注意事项是什么
    这篇文章主要介绍“使用.prop的注意事项是什么”,在日常操作中,相信很多人在使用.prop的注意事项是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”使用.prop的注意...
    99+
    2024-04-02
  • Java中Collections.emptyList()的注意事项是什么
    小编给大家分享一下Java中Collections.emptyList()的注意事项是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!偶然发现有小伙伴错误地使用...
    99+
    2023-06-14
  • Golang中interface{}的注意事项是什么
    这篇“Golang中interface{}的注意事项是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Golang中int...
    99+
    2023-07-05
  • Go中interface{}的注意事项是什么
    这篇文章主要介绍“Go中interface{}的注意事项是什么”,在日常操作中,相信很多人在Go中interface{}的注意事项是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Go中interface{...
    99+
    2023-07-05
  • vue获取dom元素子节点的方法是什么
    在Vue中,可以使用`$refs`来获取DOM元素的子节点。具体步骤如下:1. 在模板中给DOM元素加上`ref`属性,例如:`.....
    99+
    2023-08-08
    vue
  • Vue $nextTick能获取到最新Dom的原因是什么
    这篇文章主要介绍“Vue $nextTick能获取到最新Dom的原因是什么”,在日常操作中,相信很多人在Vue $nextTick能获取到最新Dom的原因是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
    99+
    2023-07-04
  • ajaxSuccess使用注意事项是什么
    本文小编为大家详细介绍“ajaxSuccess使用注意事项是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“ajaxSuccess使用注意事项是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,...
    99+
    2024-04-02
  • 连接Oracle注意事项是什么
    本篇内容介绍了“连接Oracle注意事项是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!连接Oracle 的设计可以作为ADO进行替代,...
    99+
    2023-06-17
  • return语句使用的注意事项是什么
    本篇内容主要讲解“return语句使用的注意事项是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“return语句使用的注意事项是什么”吧!   ...
    99+
    2024-04-02
  • 使用Oracle Nologging+Append注意事项是什么
    本篇内容介绍了“使用Oracle Nologging+Append注意事项是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细...
    99+
    2024-04-02
  • mysql安全设置注意事项是什么
    这篇文章主要为大家展示了“mysql安全设置注意事项是什么”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“mysql安全设置注意事项是什么”这篇文章吧。  1.如...
    99+
    2024-04-02
  • Try..Catch的注意事项有什么
    这篇文章主要介绍“Try..Catch的注意事项有什么”,在日常操作中,相信很多人在Try..Catch的注意事项有什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Try....
    99+
    2024-04-02
  • python切片中内存的注意事项是什么
    这篇文章主要介绍了python切片中内存的注意事项是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。由于 Python 列表的切片会在内存中创建新对象,因此需要注意的另一个...
    99+
    2023-06-20
  • localStorage的用法及使用注意事项是什么
    这篇文章主要讲解了“localStorage的用法及使用注意事项是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“localStorage的用法及使用注意事项是什么”吧!localStor...
    99+
    2023-06-29
  • Assert.assertEquals的使用方法及注意事项是什么
    这篇文章主要介绍了Assert.assertEquals的使用方法及注意事项是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Assert.assertEquals的使用方法及注意事项是什么文章都会有所收获,...
    99+
    2023-06-30
  • Web服务器租用注意事项是什么
    Web服务器租用注意事项是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Web服务器租用注意事项是什么?搭建网站的时候很重要的一点就是服务器的选择,一个好的服务器能够搭建出...
    99+
    2023-06-07
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作