zoukankan      html  css  js  c++  java
  • Vue 父子组件通信入门

    • 父组件向子组件传值

        1.组件实例定义方式,注意:子组件一定要使用props属性来定义父组件传递过来的数据

    <script type="text/javascript">
        // 创建 Vue 实例,得到 ViewModel
        var vm = new Vue({
          el: '#app',
          data: {
            msg: '这是父组件中的消息'
          },
          components: {
            son: {
              template: '<h1>这是子组件 --- {{finfo}}</h1>',
              props: ['finfo']
            }
          }
        });
      </script>
    

      

        2.使用v-bind或简化指令,将数据传递到子组件中

    <div id="app">
        <son :finfo="msg"></son>
    </div>
    

      

    • 子组件向父组件传值

       原理:父组件将方法的引用,传递到子组件内部,子组件在内部调用父组件传递过来的方法,同时把要发送给父组件的数据,在调用方法的时候当作参数传递进去;

       子组件内部通过this.$emit('方法名', 要传递的数据)方式,来调用父组件中的方法,同时把数据传递给父组件使用;

     <div id="app">
        <!-- 引用父组件 -->
        <son @func="getMsg"></son>
      </div>
    
      <script type="text/javascript">
        // 子组件的定义方式
        Vue.component('son', {
          template:`
           <div>
              <input type="button" value="向父组件传值" @click="sendMsg" />
            </div>
        `, // 组件模板Id
          methods: {
            sendMsg() { // 按钮的点击事件
              this.$emit('func', 'OK'); // 调用父组件传递过来的方法,同时把数据传递出去
            }
          }
        });
    
        // 创建 Vue 实例,得到 ViewModel
        var vm = new Vue({
          el: '#app',
          data: {},
          methods: {
            getMsg(val){ // 子组件中,通过 this.$emit() 实际调用的方法,在此进行定义
              alert(val);
            }
          }
        });
      </script>
    

      

    • 子组件中 data 和 props 的区别

        子组件中的data数据,不是通过父组件传递的是子组件私有的,是可读可写的;

        子组件中的所有 props中的数据,都是通过父组件传递给子组件的,是只读的;

    •  关于Vue 属性 watch,computed和methods之间的对比
    1. computed属性的结果会被缓存,除非依赖的响应式属性变化才会重新计算;主要当作属性来使用;

    2. methods方法表示一个具体的操作,主要书写业务逻辑;

    3. watch一个对象,键是需要观察的表达式,值是对应回调函数。主要用来监听某些特定数据的变化,从而进行某些具体的业务逻辑操作;可以看作是computedmethods的结合体;

  • 相关阅读:
    AUTOSAR-文档中所使用的UML文件
    开心一下-实现基于Java一个中文编程语言
    HDU 1026 Ignatius and the Princess I
    HDU 2553 (状压) N皇后问题 (2)
    UVa 11825 (状压DP) Hackers' Crackdown
    UVa 10891 (博弈+DP) Game of Sum
    LA 2965 Jurassic Remains
    HDU 2126 (背包方法数) Buy the souvenirs
    POJ 3984 迷宫问题
    POJ 3287 (基础BFS) Catch That Cow
  • 原文地址:https://www.cnblogs.com/coder-zyc/p/11928082.html
Copyright © 2011-2022 走看看