zoukankan      html  css  js  c++  java
  • vue父子组件通信

    父子组件之间可以通过props进行通信:
    组件的定义:
         1.创建component类:
                   
    var Profile = Vue.extend({
                       template: "<div>Lily</div>"; 
                   })
    

      

         2.注册一个tagnme:
                   Vue.component("me-profile",Profile);//全局注册
                   局部注册:
                             
    var vm = new Vue({
      el: "#todo",
      components: {
        "my-profile": Profile
      },
      ...
    }
    

      

    模板注意事项:
               因为 Vue 就是原生的DOM,所以有些自定义标签可能不符合DOM标准,比如想在 table 中自定义一个 tr,如果直接插入 my-component 不符合规范,所以应该这样写:
     
    <table>
      <tr is="my-component"></tr>
    </table>
     
    

      

    在子组件中有一个this.$parent和this.$root可以用来方法父组件和跟实例。(但是不推荐)
    Vue中子组件可以通过事件和父组件进行通信。向父组件发消息是通过this.$dispatch,而向子组件发送消息是通过this.$boardcast,这里都是向所有的父组件和子组件发送消息。
    子组件:
    props: {
                  url: {
                             type: Array,
                             default: function() {
                                  return []               
                             }
                        } 
              },
     methods: {
        add: function() {
          this.$dispatch("add", this.input); //这里就是向父组件发送消息
          this.input = "";
        }
      }
    

      

    父组件:
    data() {
             return {
                url:   .....
              }  
         },
     events: {
        add: function(input) {
          if(!input) return false;
          this.list.unshift({
            title: input,
            done: false
          });
        }
      }
    

      

     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
     
  • 相关阅读:
    bzoj1295 [SCOI2009]最长距离
    bzoj1853 [Scoi2010]幸运数字
    bzoj1855 [Scoi2010]股票交易
    bzoj1294 [SCOI2009]围豆豆
    bzoj1237 [SCOI2008]配对
    bzoj1084 [SCOI2005]最大子矩阵
    bzoj1068 [SCOI2007]压缩
    bzoj1082 [SCOI2005]栅栏
    soj97 旅行
    soj98 卡牌
  • 原文地址:https://www.cnblogs.com/lhy-93/p/5741487.html
Copyright © 2011-2022 走看看