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注册的元素或组件已经被正确地创建和挂载,从而避免出现访问不到的情况