zoukankan      html  css  js  c++  java
  • vue -- 父组件通过$refs获取子组件的值和方法

    前言

    在vue项目中组件之间的通讯是很常见的问题,同时也是很重要的问题,我们大致可以将其分为三种情况:

    1. 1.父传子:在父组件中绑定值,在子组件中用props接收
    2. 2.子传父:在父组件中监听一个事件,在子组件中利用$emit触发这个事件并带上数据作为第二个参数,这时父组件中监听事件的回调函数就会被调用,回调函数的参数就是子组件带上来的数据,这样就可以在父组件中使用子组件的数据了,
    3. 3.兄弟之间的传递:我们可以使用事件总线(eventBus)来轻松的解决,其实就是发布订阅者模式

    今天我们要看的是父组件如何直接调取子组件的数据和方法,而不是通过子组件传上来的

    在这里我们要理解父组件直接拿事件是在父组件上,子组件传上来数据,事件是在子组件上,是完全不同的两种情况

    代码展示

    子组件 children.vue,我们在子组件中定义了数据sonData和方法sonMethod

    // children.vue
    
    <template>
      <div>我是 children</div>
    </template>
    
    <script>
    export default {
      data: () => ({
        sonData: '我是子组件的数据!'
      }),
      methods: {
        sonMethod() {
          console.log('我是子组件的方法!')
        }
      },
      computed: {
        
      },
      created() {
    
      }
    }
    </script>

    父组件 文件

    // 父组件
    
    <template>
      <div>
        <children ref='ch'>
        </children>
        <h1 @click="onclick">父组件</h1>
      </div>
    </template>
    
    <script>
    import children from './coms/children'
    export default {
      data() {
        return {}
      },
      components: {
        children
      },
      methods: {
        onclick() {
        // 或者 let chil = this.$refs['ch']
          let chil = this.$refs.ch
    
        // 父组件可以通过$refs拿到子组件的对象
        // 然后直接调用子组件的 methods里的方法和data里的数据
          console.log(chil) //子组件对象
          console.log(chil.sonData) // 我是子组件的数据
          console.log(chil.sonMethod()) // 我是子组件的方法
        }
      }
    }
    </script>

    注意事项

    因为 ref 本身是作为渲染结果被创建的,在初始渲染的时候你不能访问它们 - 它们还不存在!,所以它不是响应式的,不能用在模板或者计算属性中。

  • 相关阅读:
    五步搞定Android开发环境部署
    Android 内存监测工具 DDMS --> Heap
    Android自动化测试之MonkeyRunner
    monkeyrunner功能函数
    python基础语法(4)
    python基础语法(3)
    python基础语法(2)
    执行插件超过2分钟超时错误,如何办?
    Dynamics 365出现数据加密错误怎么办?
    Dynamics 365执行操作报SQL Server已超时,更改这个超时设置的方法
  • 原文地址:https://www.cnblogs.com/guandekuan/p/13576975.html
Copyright © 2011-2022 走看看