什么时候用ref,什么时候不用ref

文章目录

用ref

“打在我身,疼在她心”时,用ref。比如,点击事件绑定在某个标签上,事件处理函数中却要访问另一个完全不相关的元素的真实DOM。
本例中,click事件绑定在button标签上,事件处理函数handleClick中却要访问h2元素中的内容。

<template>
  <div>
    <h2 ref="title">{{msg}}</h2>
    <button @click="handleClick">点击获取信息</button>
  </div>
</template>

<script>
export default {
  name:"MyComponent",
  data(){
    return {
      msg:"好好学习,天天向上"
    }
  },
  methods:{
    handleClick(){
      console.log(this.$refs.title);
      console.log(this.$refs.title.innerText);
    }
  }
}
</script>

在这里插入图片描述

不用ref

“打在我身,疼在我身”时,虽然ref也可以使用,但没有必要,推荐使用event.target。比如,点击事件绑定在某个标签上,事件处理函数中需要访问本元素所在DOM。
本例中,click事件绑定在h2标签上,事件处理函数handleClick中需要访问h2自身的内容。

  • 用ref
<template>
  <div>
    <h2 ref="title" @click="handleClick">{{msg}}</h2>
  </div>
</template>

<script>
export default {
  name:"MyComponent",
  data(){
    return {
      msg:"好好学习,天天向上"
    }
  },
  methods:{
    handleClick(){
      console.log(this.$refs.title);
      console.log(this.$refs.title.innerText);
    }
  }
}
</script>

在这里插入图片描述

  • 不用ref,用event.target(推荐)
<template>
  <div>
    <h2 @click="handleClick">{{msg}}</h2>
  </div>
</template>

<script>
export default {
  name:"MyComponent",
  data(){
    return {
      msg:"好好学习,天天向上"
    }
  },
  methods:{
    handleClick(event){
      console.log(event.target);
      console.log(event.target.innerText);
    }
  }
}
</script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值