vue.js中ref及$refs的使用及讲解


 

 

 

 

https://www.jianshu.com/p/623c8b009a85

 

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> 
 
image.png

其实ref除了可以获取本页面的dom元素,还可以拿到子组件中的data和去调用子组件中的方法

获取子组件中的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> 
 
image.png

调用子组件中的方法

子组件

<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> 
 
image.png

子组件调用父组件方法

子组件

<template> <div> </div> </template> <script> export default { methods: { open() { console.log("调用了"); // 调用父组件方法 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> 
 


作者:回不去的那些时光
链接:https://www.jianshu.com/p/623c8b009a85
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

https://www.cnblogs.com/dengyao-blogs/p/11350292.html

 

 

 

 

 

 

 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM