Vue中ref有什么独特作用和广泛适用场景?

2026-04-11 07:551阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计862个文字,预计阅读时间需要4分钟。

Vue中ref有什么独特作用和广泛适用场景?

引用用于给元素或子组件注册引用信息。引用信息将被注册在父组件的$refs对象上。如果用在普通DOM元素上,引用指向的就是DOM元素;如果用在子组件上,引用指向的就是组件实例。

ref 被用来给元素或子组件注册引用信息。引用信息将会注册在父组件的 $refs 对象上。如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子组件上,引用就指向组件实例。当 ref 和 v-for 一起用于元素或组件的时候,引用信息将是包含 DOM 节点或组件实例的数组。 ref

预期:string

被用来给元素或子组件注册引用信息,引用信息将会注册在父组件的$refs对象上。

Vue中ref有什么独特作用和广泛适用场景?

如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子组件上,引用就指向组件实例:

<!-- `vm.$refs.p` will be the DOM node --> <p ref="p">hello</p> <!-- `vm.$refs.child` will be the child component instance --> <child-component ref="child"></child-component>

当 v-for 用于元素或组件的时候,引用信息将是包含 DOM 节点或组件实例的数组。

关于 ref 注册时间的重要说明
因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!$refs 也不是响应式的,因此你不应该试图用它在模板中做数据绑定。

访问子组件实例或子元素
尽管存在 prop 和事件,有的时候你仍可能需要在 JavaScript 里直接访问一个子组件。为了达到这个目的,你可以通过 ref 特性为这个子组件赋予一个 ID 引用。例如:

<base-input ref="usernameInput"></base-input>

现在在你已经定义了这个 ref 的组件里,你可以使用:

this.$refs.usernameInput

来访问这个 实例,以便不时之需。比如程序化地从一个父级组件聚焦这个输入框。在刚才那个例子中,该<base-input>组件也可以使用一个类似的 ref 提供对内部这个指定元素的访问,例如:

甚至可以通过其父级组件定义方法:

methods: { // 用来从父级组件聚焦输入框 focus: function () { this.$refs.input.focus() } }

这样就允许父级组件通过下面的代码聚焦<base-input>里的输入框:

this.$refs.usernameInput.focus()

当 ref 和 v-for 一起使用的时候,你得到的引用将会是一个包含了对应数据源的这些子组件的数组。

$refs 只会在组件渲染完成之后生效,并且它们不是响应式的。这仅作为一个用于直接操作子组件的“逃生舱”——应避免在模板或计算属性中访问 $refs。

蓦然、回首,那人就在灯火阑珊处

本文共计862个文字,预计阅读时间需要4分钟。

Vue中ref有什么独特作用和广泛适用场景?

引用用于给元素或子组件注册引用信息。引用信息将被注册在父组件的$refs对象上。如果用在普通DOM元素上,引用指向的就是DOM元素;如果用在子组件上,引用指向的就是组件实例。

ref 被用来给元素或子组件注册引用信息。引用信息将会注册在父组件的 $refs 对象上。如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子组件上,引用就指向组件实例。当 ref 和 v-for 一起用于元素或组件的时候,引用信息将是包含 DOM 节点或组件实例的数组。 ref

预期:string

被用来给元素或子组件注册引用信息,引用信息将会注册在父组件的$refs对象上。

Vue中ref有什么独特作用和广泛适用场景?

如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子组件上,引用就指向组件实例:

<!-- `vm.$refs.p` will be the DOM node --> <p ref="p">hello</p> <!-- `vm.$refs.child` will be the child component instance --> <child-component ref="child"></child-component>

当 v-for 用于元素或组件的时候,引用信息将是包含 DOM 节点或组件实例的数组。

关于 ref 注册时间的重要说明
因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!$refs 也不是响应式的,因此你不应该试图用它在模板中做数据绑定。

访问子组件实例或子元素
尽管存在 prop 和事件,有的时候你仍可能需要在 JavaScript 里直接访问一个子组件。为了达到这个目的,你可以通过 ref 特性为这个子组件赋予一个 ID 引用。例如:

<base-input ref="usernameInput"></base-input>

现在在你已经定义了这个 ref 的组件里,你可以使用:

this.$refs.usernameInput

来访问这个 实例,以便不时之需。比如程序化地从一个父级组件聚焦这个输入框。在刚才那个例子中,该<base-input>组件也可以使用一个类似的 ref 提供对内部这个指定元素的访问,例如:

甚至可以通过其父级组件定义方法:

methods: { // 用来从父级组件聚焦输入框 focus: function () { this.$refs.input.focus() } }

这样就允许父级组件通过下面的代码聚焦<base-input>里的输入框:

this.$refs.usernameInput.focus()

当 ref 和 v-for 一起使用的时候,你得到的引用将会是一个包含了对应数据源的这些子组件的数组。

$refs 只会在组件渲染完成之后生效,并且它们不是响应式的。这仅作为一个用于直接操作子组件的“逃生舱”——应避免在模板或计算属性中访问 $refs。

蓦然、回首,那人就在灯火阑珊处