一、轉載聲明
本文非原創,轉載自 vue中ref的用法總結,希望大家多多支持原創。本文僅用於個人學習,如有侵權,聯系本人刪除文章!
二、獲取本頁面dom元素
<template>
<div id="app">
<div ref="testDom">11111</div>
<button @click="getTest">獲取test節點</button>
</div>
</template>
<script>
export default {
methods: {
getTest() {
console.log(this.$refs.testDom)
}
}
};
</script>
控制台輸出如下:

當然也可以通過 this.$refs.testDom.style.color = "blue" 來改變dom的樣式
三、獲取子組件中的data
子組件:
<template> <div> {{ msg }} </div> </template> <script> export default { data() { return { msg: "hello world" } } } </script>
父組件:
<template>
<div id="app">
<HelloWorld ref="hello"/>
<button @click="getHello">獲取helloworld組件中的值</button>
</div>
</template>
<script>
import HelloWorld from "./components/HelloWorld.vue";
export default {
components: {
HelloWorld
},
data() {
return {}
},
methods: {
getHello() {
console.log(this.$refs.hello.msg)
}
}
};
</script>
控制台效果如下:

四、調用子組件中的方法
子組件:
<template> <div> </div> </template> <script> export default { methods: { open() { console.log("調用到了") } } } </script>
父組件:
<template>
<div id="app">
<HelloWorld ref="hello"/>
<button @click="getHello">獲取helloworld組件中的值</button>
</div>
</template>
<script>
import HelloWorld from "./components/HelloWorld.vue";
export default {
components: {
HelloWorld
},
data() {
return {}
},
methods: {
getHello() {
this.$refs.hello.open();
}
}
};
</script>
控制台輸出如下:

