欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue中的ref和$refs的使用

程序员文章站 2022-11-09 16:05:12
ref:被用来给元素或子组件注册引用信息,引用信息将会注册在父组件的$refs对象上。如果在普通的dom元素上使用,那么指向的就是普通的dom元素。 ref 有三种用...

ref:被用来给元素或子组件注册引用信息,引用信息将会注册在父组件的$refs对象上。如果在普通的dom元素上使用,那么指向的就是普通的dom元素。

ref 有三种用法:

1、ref 加在普通的元素上,用this.ref.name 获取到的是dom元素

2、ref 加在子组件上,用this.ref.name 获取到的是组件实例,可以使用组件的所有方法。

3、如何利用 v-for 和 ref 获取一组数组或者dom 节点

普通的dom元素上使用

<div id="app7">
  <input type="text"ref="text"/ >
  <button @click="add">添加</button>
</div>
var app7=new vue({
  el:"#app7",
  data:{

  },
  methods:{
    add:function(){
      console.log(this.$refs);
    }
  }
})

子组件上使用

<div id="app7">
  <aaa ref=inputtext></aaa>
  <input type="text"ref="text" >
  <button @click="add">添加</button>
</div>
 vue.component('aaa',{
    template:"<div>我是一个组件</div>"
  })
  var app7=new vue({
    el:"#app7",
    data:{

    },
    methods:{
      add:function(){
        console.log(this.$refs.inputtext);
        console.log(this.$refs);
      }
    }
  })
  var aaa=app7.$refs.inputtext;
  //console.log(aaa);
  //console.log(aaa.$el.innertext);

$refs:一个对象,持有注册过 ref 特性 的所有 dom 元素和组件实例

注意:$refs只会在组件渲染完成之后生效,并且它们不是响应式的。这只意味着一个直接的子组件封装的“逃生舱”——你应该避免在模板或计算属性中访问 $refs

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。