Vue 实例中使用$refs的注意事项

作者:随风丶逆风 时间:2024-05-02 16:36:01 

在开发过程中,经常会通过实例的vm.$refs(this.$refs)取得通过ref注册过的组件,并进行相应操作,但存在取不到元素的情况,其根本原因是因为$refs只能取得mounted(渲染)之后的元素。

Vue 实例中使用$refs的注意事项

例如,在这种情况中,若flag从真值切换到假值取不到节点是正常的,因为v-if如果为假值,那么该节点不会被渲染。

但如果从假值切换到真值时,也可能取不到节点,这是因为渲染需要时间,通常可以使用$nextTick()解决。


...
<el-table v-if="flag" ref="table">
 <el-table-column prop="prop1"></el-table-column>
 <el-table-column prop="prop2"></el-table-column>
</el-table>
...

export default {
 methods: {
   this.$refs.table.XXX()
 }
}

但存在一个极特殊的情况,第一次页面渲染的时候,$refs也取不到值。这个时候就要考虑v-show进行组件元素的隐藏与展示。

因为v-show是通过css的display:none进行隐藏控制,所以一开始就会渲染,肯定能够取到元素

补充:Vue.js中ref ($refs)用法举例总结及应注意的坑

一、根据官方文档总结的用法:

看Vue.js文档中的ref部分,自己总结了下ref的使用方法以便后面查阅。

1、ref使用在外面的组件上

HTML 部分


<div id="ref-outside-component" v-on:click="consoleRef">
 <component-father ref="outsideComponentRef">
 </component-father>
 <p>ref在外面的组件上</p>
</div>

js部分


var refoutsidecomponentTem={
   template:"<div class='childComp'><h5>我是子组件</h5></div>"
 };
 var refoutsidecomponent=new Vue({
   el:"#ref-outside-component",
   components:{
     "component-father":refoutsidecomponentTem
   },
   methods:{
     consoleRef:function () {
       console.log(this); // #ref-outside-component   vue实例
       console.log(this.$refs.outsideComponentRef); // div.childComp vue实例
     }
   }
 });

2、ref使用在外面的元素上

HTML部分


<!--ref在外面的元素上-->
<div id="ref-outside-dom" v-on:click="consoleRef" >
 <component-father>
 </component-father>
 <p ref="outsideDomRef">ref在外面的元素上</p>
</div>

JS部分


var refoutsidedomTem={
   template:"<div class='childComp'><h5>我是子组件</h5></div>"
 };
 var refoutsidedom=new Vue({
   el:"#ref-outside-dom",
   components:{
     "component-father":refoutsidedomTem
   },
   methods:{
     consoleRef:function () {
       console.log(this); // #ref-outside-dom  vue实例
       console.log(this.$refs.outsideDomRef); //  <p> ref在外面的元素上</p>
     }
   }
 });

3、ref使用在里面的元素上---局部注册组件

HTML部分


<!--ref在里面的元素上-->
<div id="ref-inside-dom">
 <component-father>
 </component-father>
 <p>ref在里面的元素上</p>
</div>

JS部分


 var refinsidedomTem={
   template:"<div class='childComp' v-on:click='consoleRef'>" +
           "<h5 ref='insideDomRef'>我是子组件</h5>" +
        "</div>",
   methods:{
     consoleRef:function () {
       console.log(this); // div.childComp  vue实例
       console.log(this.$refs.insideDomRef); // <h5 >我是子组件</h5>
     }
   }
 };
 var refinsidedom=new Vue({
   el:"#ref-inside-dom",
   components:{
     "component-father":refinsidedomTem
   }
 });

4、ref使用在里面的元素上---全局注册组件

HTML部分


<!--ref在里面的元素上--全局注册-->
<div id="ref-inside-dom-all">
 <ref-inside-dom-quanjv></ref-inside-dom-quanjv>
</div>

JS部分


 Vue.component("ref-inside-dom-quanjv",{
   template:"<div class='insideFather'> " +
         "<input type='text' ref='insideDomRefAll' v-on:input='showinsideDomRef'>" +
         " <p>ref在里面的元素上--全局注册 </p> " +
        "</div>",
   methods:{
     showinsideDomRef:function () {
       console.log(this); //这里的this其实还是div.insideFather
       console.log(this.$refs.insideDomRefAll); // <input type="text">
     }
   }
 });
 var refinsidedomall=new Vue({
   el:"#ref-inside-dom-all"
 });

二、应注意的坑

1、如果通过v-for 遍历想加不同的ref时记得加 :号,即 :ref =某变量 ;

这点和其他属性一样,如果是固定值就不需要加 :号,如果是变量记得加 :号

Vue 实例中使用$refs的注意事项

2、通过 :ref =某变量 添加ref(即加了:号) ,如果想获取该ref时需要加 [0],如this.$refs[refsArrayItem] [0];如果不是:ref =某变量的方式而是 ref =某字符串时则不需要加,如this.$refs[refsArrayItem]

Vue 实例中使用$refs的注意事项

加和不加[0]的区别--未展开

Vue 实例中使用$refs的注意事项

加和不加[0]的区别--展开了

3、想在element ui 对话框打开后取dom时,应该使用$nextTick,而不是直接使用this.$refs. imgLocal2:


   console.log('this.$refs.imgLocal2外面', this.$refs.imgLocal2);
   setTimeout(() => {
    console.log('this.$refs.imgLocal2 setTimeout', this.$refs.imgLocal2);
   }, 500); // 不推荐
   this.$nextTick(() => {
    console.log('this.$refs.imgLocal2 $nextTick', this.$refs.imgLocal2);
   });

Vue 实例中使用$refs的注意事项

以上为个人经验,希望能给大家一个参考,也希望大家多多支持asp之家。如有错误或未考虑完全的地方,望不吝赐教。

来源:https://blog.csdn.net/sinat_36521655/article/details/99655967

标签:Vue,$refs
0
投稿

猜你喜欢

  • Linux下mysql源码安装笔记

    2024-01-19 23:45:08
  • Python使用正则表达式实现爬虫数据抽取

    2021-01-22 15:00:24
  • Python多进程分块读取超大文件的方法

    2023-12-07 02:19:28
  • Python接口自动化浅析pymysql数据库操作流程

    2024-01-16 16:33:02
  • 动态加载JS文件的三种方法

    2024-05-21 10:14:28
  • python super的使用方法及实例详解

    2023-08-19 11:04:49
  • python中的生成器、迭代器、装饰器详解

    2022-03-01 20:36:46
  • 详细解读php的命名空间(一)

    2023-06-19 08:02:59
  • Python做文本按行去重的实现方法

    2021-12-31 17:41:07
  • MySQL中InnoDB的间隙锁问题

    2024-01-25 11:13:58
  • Go语言Http Server框架实现一个简单的httpServer

    2024-02-19 11:04:33
  • 微软建议的ASP性能优化28条守则(4)

    2008-02-26 17:57:00
  • 使用MySQL实现select into临时表的功能

    2024-01-25 01:14:53
  • 在keras中实现查看其训练loss值

    2021-03-05 05:29:44
  • python通用数据库操作工具 pydbclib的使用简介

    2024-01-24 14:24:16
  • Python 调用C++封装的进一步探索交流

    2022-10-29 22:43:43
  • 邮箱正则表达式实现代码(针对php)

    2024-05-03 15:48:55
  • mysql回表查询是什么,回表查询的使用

    2024-01-26 01:57:17
  • Python os模块中的isfile()和isdir()函数均返回false问题解决方法

    2022-04-16 19:40:58
  • 对Python获取屏幕截图的4种方法详解

    2023-11-19 09:45:41
  • asp之家 网络编程 m.aspxhome.com