因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!$refs
也不是响应式的,因此你不应该试图用它在模板中做数据绑定。
只有等页面加载完成好之后你才能调用 this.$refs
,如果你使用v-if /v-for
渲染页面的话,那么在刚开始页面没没渲染之前你是拿不到this.$refs
的,所以要等到页面渲染之后拿才可以
解决办法:
-
如果你在
created/mounted
里获取this.$refs
,因为dom还未完全加载,所以你是拿不到的,update
阶段则是完成了数据更新到 DOM 的阶段(当这个钩子被调用时,组件 DOM 已经更新),此时,就可以使用this.$refs
了 -
如果写在method中,那么可以使用
this.$nextTick(() => {})
等页面渲染好再调用