对vue.js中this.$emit的深入理解


Posted in Javascript onFebruary 23, 2018

对于vue.js中的this.emit的理解:this.emit(‘increment1',”这个位子是可以加参数的”);其实它的作用就是触发自定义函数。

看例子:

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title></title>
</head>
<script src="vue.js"></script>
<body>
<div id="counter-event-example">
 <p>{{ total }}</p>
 <button-counter v-on:increment1="incrementTotal1"></button-counter>
 <button-counter v-on:increment2="incrementTotal2"></button-counter>
</div>
</body>
<script>
 Vue.component('button-counter', {
 template: '<button v-on:click="increment">{{ counter }}</button>',
 data: function () {
  return {
  counter: 0
  }
 },
 methods: {
  increment: function () {
  this.counter += 1;
  this.$emit('increment1',"这个位子是可以加参数的");//触发自定义increment1的函数。此处的increment1函数就是 incrementTotal1函数。
//  this.$emit('increment2'); //此时不会触发自定义increment2的函数。
  }
 }
 });
 new Vue({
 el: '#counter-event-example',
 data: {
  total: 0
 },
 methods: {
  incrementTotal1: function (e) {
  this.total += 1;
  console.log(e);
  },
  incrementTotal2: function () {
  this.total += 1;
  }
 }
 })
</script>
</html>

对上面的例子进行进一步的解析:

1、首先看 自定组件button-counter ,给其绑定了方法 :increment;

2、点击button时会执行函数 increment,increment中有 this.$emit(‘increment1',”这个位子是可以加参数的”);

3、当increment执行时,就会触发自定函数increment1,也就是incrementTotal1函数;

4、而increment执行时没有触发自定义函数increment2,所以点击第二个按钮不执行incrementTotal2的函数。

以上这篇对vue.js中this.$emit的深入理解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery struts 验证唯一标识(公用方法)
Mar 27 Javascript
js中对象的声明方式以及数组的一些用法示例
Dec 11 Javascript
SuperSlide标签切换、焦点图多种组合插件
Mar 14 Javascript
jQuery判断多个input file 都不能为空的例子
Jun 23 Javascript
js 开发之autocomplete=&quot;off&quot;在chrom中失效的解决办法
Sep 28 Javascript
Angular4绑定html内容出现警告的处理方法
Nov 03 Javascript
vue实现商城上货组件简易版
Nov 27 Javascript
three.js实现3D模型展示的示例代码
Dec 31 Javascript
详谈vue+webpack解决css引用图片打包后找不到资源文件的问题
Mar 06 Javascript
vue-cli项目优化方法- 缩短首屏加载时间
Apr 01 Javascript
vue+element实现表格新增、编辑、删除功能
May 28 Javascript
vue-cli3配置favicon.ico和title的流程
Oct 27 Javascript
基于vue.js中事件修饰符.self的用法(详解)
Feb 23 #Javascript
vue.js2.0点击获取自己的属性和jquery方法
Feb 23 #jQuery
vue中动态绑定表单元素的属性方法
Feb 23 #Javascript
Vue之Vue.set动态新增对象属性方法
Feb 23 #Javascript
vue2.0在没有dev-server.js下的本地数据配置方法
Feb 23 #Javascript
Vue实现带进度条的文件拖动上传功能
Feb 23 #Javascript
详解vue2.0 不同屏幕适配及px与rem转换问题
Feb 23 #Javascript
You might like
如何在WIN2K下安装PHP4.04
2006/10/09 PHP
php stream_get_meta_data返回值
2013/09/29 PHP
php实现上传图片文件代码
2015/07/19 PHP
php检查字符串中是否有外链的方法
2015/07/29 PHP
Linux平台PHP5.4设置FPM线程数量的方法
2016/11/09 PHP
phpcms的分类名称和类别名称的调用
2017/01/05 PHP
php 常用的系统函数
2017/02/07 PHP
doctype后如何获得body.clientHeight的方法
2007/07/11 Javascript
ExtJS下grid的一些属性说明
2009/12/13 Javascript
学习Angular中作用域需要注意的坑
2016/08/17 Javascript
javascript如何创建对象
2016/08/29 Javascript
Node.js复制文件的方法示例
2016/12/29 Javascript
js 显示日期时间的实例(时间过一秒加1)
2017/10/25 Javascript
VUE组件中的 Drawer 抽屉实现代码
2019/08/06 Javascript
JS实现TITLE悬停长久显示效果完整示例
2020/02/11 Javascript
Javascript新手入门之字符串拼接与变量的应用
2020/12/03 Javascript
[04:52]DOTA2亚洲邀请赛附加赛 TOP10精彩集锦
2015/01/29 DOTA
[36:20]KG vs SECRET 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/19 DOTA
[57:31]DOTA2-DPC中国联赛 正赛 SAG vs CDEC BO3 第一场 2月1日
2021/03/11 DOTA
python操作MongoDB基础知识
2013/11/01 Python
Django 拆分model和view的实现方法
2019/08/16 Python
对YOLOv3模型调用时候的python接口详解
2019/08/26 Python
python @propert装饰器使用方法原理解析
2019/12/25 Python
django API 中接口的互相调用实例
2020/04/01 Python
python实现数字炸弹游戏
2020/07/17 Python
Python如何创建装饰器时保留函数元信息
2020/08/07 Python
HTML5引入的新数组TypedArray介绍
2012/12/24 HTML / CSS
JINS眼镜官方网站:日本最大的眼镜邮购
2016/10/14 全球购物
中东最大的在线宠物店:Dubai Pet Food
2020/06/11 全球购物
银行求职推荐信范文
2013/11/30 职场文书
公司开业庆典策划方案
2014/06/04 职场文书
2014年社区民政工作总结
2014/12/02 职场文书
入党积极分子培养人意见
2015/06/02 职场文书
Python爬虫之爬取哔哩哔哩热门视频排行榜
2021/04/28 Python
MySQL 用 limit 为什么会影响性能
2021/09/15 MySQL
win10识别不了U盘怎么办 win10系统读取U盘失败的解决办法
2022/08/05 数码科技