vuejs父子组件通信的成绩

发布时间:2019-12-02 10:22 来源:互联网 以后栏目:web技巧类

父子组件之间可以经过过程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

   });

  }

 } 

以上就是本文的全部内容,欲望对大年夜家的进修有所赞助,也欲望大年夜家多多支撑IIS7站长之家。

  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、
  • 1、
  • 2、
  • 3、
  • 4、
  • 5、
  • 6、
  • 7、
  • 8、
  • 9、
  • 10、
  • 11、
  • 12、
  • 13、
  • 14、
  • 15、
  • 16、
  • 17、
  • 18、
  • 19、
  • 20、
  • 21、
  • 22、
  • 23、
  • 24、
  • 25、