当前位置: 移动技术网 > IT编程>脚本编程>vue.js > Vue自定义事件(详解)

Vue自定义事件(详解)

2017年12月12日  | 移动技术网IT编程  | 我要评论

男童不愿上学被打,mysql触发器,年华 庄飞扬

前面的话

父组件使用props传递数据给子组件,子组件怎么跟父组件通信呢?这时,vue的自定义事件就派上用场了。本文将详细介绍vue自定义事件

事件绑定

每个 vue 实例都实现了事件接口 (events interface),即

使用 $on(eventname) 监听事件
使用 $emit(eventname) 触发事件

[注意]vue 的事件系统分离自浏览器的eventtarget api。尽管它们的运行类似,但是 $on 和 $emit 不是addeventlistener 和 dispatchevent 的别名

另外,父组件可以在使用子组件的地方直接用 v-on 来监听子组件触发的事件

[注意]不能用 $on 侦听子组件抛出的事件,而必须在模板里直接用 v-on 绑定

<div id="example">
 <parent></parent>
</div>
<script>
var childnode = {
 template: `<button @click="incrementcounter">{{ counter }}</button>`,
 data(){
  return {
   counter: 0
  }
 },
 methods:{
  incrementcounter(){
   this.counter ++;
   this.$emit('increment');
  }
 },
}
var parentnode = {
 template: `
 <div class="parent">
  <p>{{total}}</p>
  <child @increment="incrementtotal"></child>
  <child @increment="incrementtotal"></child>
 </div>
 `,
 components: {
  'child': childnode
 },
 data(){
  return {
   'total':0
  }
 },
 methods:{
  incrementtotal(){
   this.total ++;
  }
 }
};
// 创建根实例
new vue({
 el: '#example',
 components: {
  'parent': parentnode
 }
})
</script>

命名约定

自定义事件的命名约定与组件注册及props的命名约定都不相同,由于自定义事件实质上也是属于html的属性,所以其在html模板中,最好使用中划线形式

<child @pass-data="getdata"></child>

而子组件中触发事件时,同样使用中划线形式

 this.$emit('pass-data',this.childmsg)

数据传递

子组件通过$emit可以触发事件,第一个参数为要触发的事件,第二个事件为要传递的数据

this.$emit('pass-data',this.childmsg)

父组件通过$on监听事件,事件处理函数的参数则为接收的数据

getdata(value){
   this.msg = value;
}
<div id="example">
 <parent></parent>
</div>
<script>
var childnode = {
 template: `
 <div class="child">
  <div>
   <span>子组件数据</span>
   <input v-model="childmsg" @input="data">
  </div>
  <p>{{childmsg}}</p>
 </div>
 `,
 data(){
  return{
   childmsg:''
  }
 },
 methods:{
  data(){
   this.$emit('pass-data',this.childmsg)
  }
 }
}
var parentnode = {
 template: `
 <div class="parent">
  <div>
   <span>父组件数据</span>
   <input v-model="msg">
  </div>
  <p>{{msg}}</p>
  <child @pass-data="getdata"></child>
 </div>
 `,
 components: {
  'child': childnode
 },
 data(){
  return {
   'msg':'match'
  }
 },
 methods:{
  getdata(value){
   this.msg = value;
  }
 }
};
// 创建根实例
new vue({
 el: '#example',
 components: {
  'parent': parentnode
 }
})
</script>

sync修饰符

在一些情况下,可能会需要对一个 prop 进行双向绑定。事实上,这正是vue1.x中的 .sync修饰符所提供的功能。当一个子组件改变了一个 prop 的值时,这个变化也会同步到父组件中所绑定的值。这很方便,但也会导致问题,因为它破坏了单向数据流的假设。由于子组件改变 prop 的代码和普通的状态改动代码毫无区别,当光看子组件的代码时,完全不知道它何时悄悄地改变了父组件的状态。这在 debug 复杂结构的应用时会带来很高的维护成本,上面所说的正是在 2.0 中移除 .sync 的理由

从 2.3.0 起重新引入了 .sync 修饰符,但是这次它只是作为一个编译时的语法糖存在。它会被扩展为一个自动更新父组件属性的 v-on 侦听器

<comp :foo.sync="bar"></comp>

会被扩展为:

<comp :foo="bar" @update:foo="val => bar = val"></comp>

当子组件需要更新 foo 的值时,它需要显式地触发一个更新事件:

this.$emit('update:foo', newvalue)

因此,可以使用.sync来简化自定义事件的操作,实现子组件向父组件的数据传递

<div id="example">
 <parent></parent>
</div>
<script src="https://unpkg.com/vue"></script>
<script>
var childnode = {
 template: `
 <div class="child">
  <div>子组件数据:{{childmsg}}</div>
  <input v-model="childmsg">
  <button @click=add >+1</button>
 </div>
 `,
 data(){
  return{
   childmsg: 0
  }
 },
 methods:{
  add(){
   this.childmsg++;
   this.$emit('update:foo',this.childmsg);
  }
 }
};
var parentnode = {
 template: `
 <div class="parent">
  <p>父组件数据:{{msg}}</p>
  <child :foo.sync="msg"></child>
 </div>
 `,
 components: {
  'child': childnode
 },
 data(){
  return {
   'msg':0
  }
 }
};
// 创建根实例
new vue({
 el: '#example',
 components: {
  'parent': parentnode
 }
})
</script>

以上这篇vue自定义事件(详解)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网