目录
- 1. 基本知识
- 2. Demo
1. 基本知识
在Vue.js中,$refs
是一个特殊的属性,用于在组件内部直接访问子组件或者DOM元素
作用:
-
访问DOM元素: 直接访问模板中的DOM元素,以便执行DOM操作,如聚焦、改变样式等
-
访问子组件: 直接访问子组件的属性或方法,而不是通过props和事件来进行通信。
$refs
提供了一种直接的方式来访问子组件的实例
在模板中,可以使用ref属性来标记一个元素或者子组件,然后通过this.$refs
来访问它们
此处在自身的项目做演示,对此,代码并不是很全面给出:
<template><basic-container><input type="text" ref="textInput"/><button ref="buttonclick" @click="focusInput">Focus Input</button><el-form :inline="true" ref="formInline" :model="formInline" label-width="80px"><el-form-item label="机种"><el-select v-model="formInline.model" placeholder="机种">methods: {focusInput(){console.log(this.$refs.textInput);console.log(this.$refs.textInput.value)console.log(this.$refs.buttonclick)console.log(this.$refs.formInline)},
截图如下:
最终展示如下:
输入text并且选中表单(机种以及设备编号的选项),最后点击Focus Input
会出现如下:
2. Demo
为了更好的了解剖析,此处给出完整例子:
<template><div class="school"><h2>学校名称:{{name}}</h2><h2>学校地址:{{address}}</h2></div>
</template><script>export default {name:'School',data() {return {name:'码农研究僧',address:'CSDN'}},}
</script><style>.school{background-color: gray;}
</style>
对应引入上面的Vue模块:
<template><div><h1 v-text="msg" ref="title"></h1><button ref="btn" @click="showDOM">点我输出上方的DOM元素</button><School ref="sch"/></div>
</template><script>//引入School组件import School from './components/School'export default {name:'App',components:{School},data() {return {msg:'欢迎学习Vue!'}},methods: {showDOM(){console.log(this.$refs.title) //真实DOM元素console.log(this.$refs.btn) //真实DOM元素console.log(this.$refs.sch) //School组件的实例对象(vc)}},}
</script>
以及其中的main.js文件:
//引入Vue
import Vue from 'vue'
//引入App
import App from './App.vue'
//关闭Vue的生产提示
Vue.config.productionTip = false//创建vm
new Vue({el:'#app',render: h => h(App)
})
当在Vue.js中使用ref指令时,它可以用于普通的DOM元素或者组件
- ref用在普通的DOM元素上,那么
$refs
引用将指向对应的DOM元素 - 用在子组件上,
$refs
引用将指向子组件的实例 v-for
指令用于元素或组件时,ref注册的信息将会是一个包含DOM节点或组件实例的数组
需要注意的是,ref注册的时间非常重要。因为ref本身是作为渲染结果被创建的,所以在初始渲染的过程中无法访问它们,因为它们还不存在
此外,$refs
不是响应式的,因此不应该试图在模板中使用它进行数据绑定
在使用$refs
时,需要确保在组件渲染完成后再去访问它们,例如在mounted生命周期钩子中,这样可以确保ref注册的元素或组件已经被正确地创建和挂载,从而避免出现访问不到的情况