vue中的ref其實功能很強大,下面介紹一下如何使用事甜。
基本用法谬泌,本頁面獲取dom元素
<template>
<div id="app">
<div ref="testDom">11111</div>
<button @click="getTest">獲取test節(jié)點</button>
</div>
</template>
<script>
export default {
methods: {
getTest() {
console.log(this.$refs.testDom)
}
}
};
</script>
其實ref除了可以獲取本頁面的dom元素,還可以拿到子組件中的data和去調(diào)用子組件中的方法
獲取子組件中的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>
調(diào)用子組件中的方法
子組件
<template>
<div>
</div>
</template>
<script>
export default {
methods: {
open() {
console.log("調(diào)用到了")
}
}
}
</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>
子組件調(diào)用父組件方法
子組件
<template>
<div>
</div>
</template>
<script>
export default {
methods: {
open() {
console.log("調(diào)用了");
// 調(diào)用父組件方法
this.$emit("refreshData");
}
}
}
</script>
父組件
<template>
<div id="app">
<HelloWorld ref="hello" @refreshData="getData"/>
<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()
},
getData() {
console.log('111111')
}
}
};
</script>
未完待續(xù)