接上篇,vue的父组件向子组件获取值,如果父组件需要主动调用子组件中的属性方法该如何实现?
获取方法
1、 父组件中使用子组件的时候在给子组件定义一个ref属性
2、父组件可以通过this.$refs.XXX,来操作子组件中的属性和方法
子组件Sub1.vue
<template> <module :title="title" /> <button :click="run()"></button> </template> <script> export default { name: "Sub1", data() { return {
//父组件可以通过定义的ref调用到title title: '' } } ,methods { run() { //父组件可以通过定义的ref调用到该方法。 console.log("sub1"); } } } </script>
父组件
<template> <!--这里使用子组件的时候定义一个ref属性1--> <sub1 ref="sub"/>
<button @click="callChild()"></button> </template> <script>//导入子组件import Sub1 from './Sub1.vue' export default { name: 'app', data() { return { title : 'test' } },methods { callChild() {
//这里就可以使用到子组件里面的title属性 console.log(this.$refs.title)
//这样可以使用到子组件的方法
this.$ref.run(); } }, components: { Sub1 //挂载子组件Sub1 } } </script>
博主:测试生财(一个不为996而996的测开码农)
座右铭:专注测试开发与自动化运维,努力读书思考写作,为内卷的人生奠定财务自由。
内容范畴:技术提升,职场杂谈,事业发展,阅读写作,投资理财,健康人生。
csdn:https://blog.csdn.net/ccgshigao
博客园:https://www.cnblogs.com/qa-freeroad/
51cto:https://blog.51cto.com/14900374
微信公众号:测试生财(定期分享独家内容和资源)