父子组件之间可以通过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
   });
  }
 } 
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎点击右下角反馈进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。