Vue 事件处理操作实例详解


Posted in Javascript onMarch 05, 2019

本文实例讲述了Vue 事件处理操作。分享给大家供大家参考,具体如下:

1 监听事件

可以用 v-on 指令监听 DOM 事件,并在触发时运行一些 JavaScript 代码。

html:

<div id="app1">
  <button v-on:click="counter +=1">递增</button>
  <p>按钮已被点击 {{ counter }} 次。</p>
</div>

js:

var app1 = new Vue({
  el: "#app1",
  data: {
    counter: 0
  }
});

效果:

Vue 事件处理操作实例详解

2 事件处理方法

然而许多事件处理逻辑会更为复杂,所以直接把 JavaScript 代码写在 v-on 指令中是不可行的。因此v-on还可以接收一个需要调用的方法名称。

html:

<div id="app2">
  <button v-on:click="greet">问候</button>
</div>

js:

var app2 = new Vue({
  el: "#app2",
  data: {
    name: 'Deniro'
  },
  methods: {
    greet: function (event) {
      //这里的 this 指向的是当前 Vue 实例
      console.log('你好 ' + this.name + '!');
      if (event) {
        console.log(event.target.tagName);
      }
    }
  }
});

效果:

Vue 事件处理操作实例详解

也可以直接调用 Vue 实例定义的函数:

Vue 事件处理操作实例详解

3 内联处理器中的方法

除了直接绑定到一个方法,也可以在内联 JavaScript 语句中调用方法:

html:

<div id="app3">
  <button v-on:click="greet('你好')">问候</button>
</div>

js:

var app3 = new Vue({
  el: "#app3",
  methods: {
    greet: function (message) {
      console.log(message);
    }
  }
});

有时也需要在内联语句处理器中访问原始的 DOM 事件。可以用特殊变量 $event 把它传入方法:

html:

<button v-on:click="warn('表单已被禁用',$event)">提交</button>

js:

methods: {
  ...
  warn: function (message,event) {
    //访问原生对象
    if(event){
      event.preventDefault();
    }
    console.log(message);
  }
}

4 事件修饰符

在事件处理程序中调用 event.preventDefault()event.stopPropagation() 是非常常见的需求。尽管我们可以在方法中轻松实现这点,但更好的方式是:方法只有纯粹的数据逻辑,而不是去处理 DOM 事件细节。

为了解决这个问题,Vue.js 为 v-on 提供了事件修饰符。之前提过,修饰符是由点开头的指令后缀来表示的。

  • .stop
  • .prevent
  • .capture
  • .self
  • .once
  • .passive
<!--阻止单击事件继续传播-->
<a v-on:click.stop="doThis"></a>
<!--提交事件不再重载页面-->
<form v-on:submit.prevent="onSubmit"></form>
<!--串联修饰符-->
<a v-on:click.stop.prevent="doThat"></a>
<!--只有修饰符-->
<form v-on:submit.prevent></form>
<!--添加事件监听器时使用事件捕获模式-->
<!--即元素自身触发的事件先在此处理,然后才交由内部元素-->
<div v-on:click.capture="doThis">...</div>
<!--在 event.target 为当前元素自身时触发处理函数-->
<!--即事件不是从内部元素触发的-->
<div v-on:click.self="doThat">...</div>

使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生。因此,用 v-on:click.prevent.self 会阻止所有的点击,而 v-on:click.self.prevent 只会阻止对元素自身的点击。
2.1.4 新增

<!--点击事件只会触发一次-->
<a v-on:click.once="doThis"></a>

不像其它只能对原生的 DOM 事件起作用的修饰符,.once 修饰符还能被用到自定义的组件事件上。

2.3.0 新增

Vue 还对应 addEventListener 中的 passive 选项提供了 .passive 修饰符。

<!--滚动事件的默认行为将会被立即触发(不会等待 onScroll 事件完成)-->
<!--包含 event.preventDefault() 的情况-->
<div v-on:scroll.passive="onScroll">...</div>

这个 .passive 修饰符尤其能够提升移动端的性能。

不要把 .passive 和 .prevent 一起使用,因为 .prevent 将会被忽略,同时浏览器可能会向你展示一个警告。请记住,.passive 会告诉浏览器你不想阻止事件的默认行为。

5 按键修饰符

在监听键盘事件时,我们经常需要检查常见的键值。Vue 允许为 v-on 在监听键盘事件时添加按键修饰符:

<!--keyCode 为 13 时调用 vm.submit()-->
<input v-on:keyup.13="submit">

记住所有的 keyCode 比较困难,所以 Vue 为最常用的按键提供了别名:

<!--使用按键别名-->
<input v-on:keyup.enter="submit">
<!--使用缩写语法-->
<input @keyup.enter="submit">

全部的按键别名:

  • .enter
  • .tab
  • .delete (捕获“删除”和“退格”键)
  • .esc
  • .space
  • .up
  • .down
  • .left
  • .right

可以通过全局 config.keyCodes 对象自定义按键修饰符别名:

//自定义按键的修饰符别名
Vue.config.keyCodes.f1 = 112;

自动匹配按键修饰符

2.5.0 新增

你也可直接将 KeyboardEvent.key 暴露的任意有效按键名转换为 kebab-case 来作为修饰符:

<input @keyup.page-down="onPageDown">

在上面的例子中,处理函数仅在 $event.key === 'PageDown' 时被调用。

有一些按键 (.esc 以及所有的方向键) 在 IE9 中有不同的 key 值, 如果你想支持 IE9,它们的内置别名应该是首选。

6 系统修饰键

2.1.0 新增

可以用如下修饰符来实现仅在按下相应按键时才触发鼠标或键盘事件的监听器。

  • .ctrl
  • .alt
  • .shift
  • .meta

注意:在 Mac 系统键盘上,meta 对应 command 键 (⌘)。在 Windows 系统键盘 meta 对应 Windows 徽标键 (⊞)。在 Sun 操作系统键盘上,meta 对应实心宝石键 (◆)。在其他特定键盘上,尤其在 MIT 和 Lisp 机器的键盘、以及其后继产品,比如 Knight 键盘、space-cadet 键盘,meta 被标记为“META”。在 Symbolics 键盘上,meta 被标记为“META”或者“Meta”。

<!--Alt + C-->
<input @keyup.alt.67="clear">
<!--Ctrl + Click-->
<div @click.ctrl="doSomething">Do something</div>

请注意修饰键与常规按键不同,在和 keyup 事件一起用时,事件触发时修饰键必须处于按下状态。换句话说,只有在按住 ctrl 的情况下释放其它按键,才能触发keyup.ctrl。而单单释放 ctrl 也不会触发事件。如果你想要这样的行为,请为 ctrl 换用 keyCode:keyup.17

6.1 .exact 修饰符

2.5.0 新增

.exact 修饰符允许你控制由精确的系统修饰符组合触发的事件。

<!--Ctrl 或 Alt 或 Shift 被一同按下时会触发-->
<button @click.ctrl="onClick">A</button>
<!--有且只有 Ctrl 被按下时才会触发-->
<button @click.ctrl.exact="onCtrlClick">A</button>
<!--没有任何系统修饰符被按下时才会触发-->
<button @click.exact="onClick">A</button>

6.2 鼠标按钮修饰符

2.2.0 新增

  • .left
  • .right
  • .middle

这些修饰符会限制处理函数仅响应特定的鼠标按钮。

7 为什么在 HTML 中监听事件?

你可能注意到这种事件监听的方式违背了关注点分离 (separation of concern) 这个长期以来的优良传统。但不必担心,因为所有的 Vue.js 事件处理方法和表达式都严格绑定在当前视图的 ViewModel 上,它不会导致任何维护上的困难。实际上,使用 v-on 有几个好处:

扫一眼 HTML 模板便能轻松定位在 JavaScript 代码里对应的方法。

因为你无须在 JavaScript 里手动绑定事件,你的 ViewModel 代码可以是非常纯粹的逻辑,和 DOM 完全解耦,更易于测试。

当一个 ViewModel 被销毁时,所有的事件处理器都会自动被删除。你无须担心如何自己清理它们。

希望本文所述对大家vue.js程序设计有所帮助。

Javascript 相关文章推荐
有关js的变量作用域和this指针的讨论
Dec 16 Javascript
JQuery插件Style定制化方法的分析与比较
May 03 Javascript
Extjs显示从数据库取出时间转换JSON后的出现问题
Nov 20 Javascript
JS的Document属性和方法小结
Sep 17 Javascript
Jquery实现仿腾讯微博发表广播
Nov 17 Javascript
jQuery插件MixItUp实现动画过滤和排序
Apr 12 Javascript
jquery实现仿JqueryUi可拖动的DIV实例
Jul 31 Javascript
Jquery on绑定的事件 触发多次实例代码
Dec 08 Javascript
js实现九宫格的随机颜色跳转
Feb 19 Javascript
bootstrap实现二级下拉菜单效果
Nov 23 Javascript
vue实现提示保存后退出的方法
Mar 15 Javascript
详解在React.js中使用PureComponent的重要性和使用方式
Jul 10 Javascript
Vue插槽原理与用法详解
Mar 05 #Javascript
JavaScript基于遍历操作实现对象深拷贝功能示例
Mar 05 #Javascript
JavaScript函数定义方法实例详解
Mar 05 #Javascript
C#程序员入门学习微信小程序的笔记
Mar 05 #Javascript
JavaScript函数的4种调用方法实例分析
Mar 05 #Javascript
微信小程序保存多张图片的实现方法
Mar 05 #Javascript
JS添加或删除HTML dom元素的方法实例分析
Mar 05 #Javascript
You might like
如何去掉文章里的 html 语法
2006/10/09 PHP
yii框架中的Url生产问题小结
2012/01/16 PHP
基于php和mysql的简单的dao类实现crud操作功能
2014/01/27 PHP
php制作文本式留言板
2015/03/18 PHP
php微信支付接口开发程序
2016/08/02 PHP
ThinkPHP5框架中使用JWT的方法示例
2020/06/03 PHP
THINKPHP5分页数据对象处理过程解析
2020/10/28 PHP
JavaScript:new 一个函数和直接调用函数的区别分析
2013/07/10 Javascript
js的Boolean对象初始值示例
2014/03/04 Javascript
解决html按钮切换绑定不同函数后点击时执行多次函数问题
2014/05/14 Javascript
javascript学习笔记(三)BOM和DOM详解
2014/09/30 Javascript
javascript实现判断鼠标的状态
2015/07/10 Javascript
jQuery实现圣诞节礼物传送(花式轮播)
2016/12/25 Javascript
Angular搜索 过滤 批量删除 添加 表单验证功能集锦(实例代码)
2017/10/25 Javascript
JavaScript 隐性类型转换步骤浅析
2018/03/15 Javascript
vue+axios+promise实际开发用法详解
2018/10/15 Javascript
IntelliJ IDEA编辑器配置vue高亮显示
2019/09/26 Javascript
js判断在哪个浏览器打开项目的方法
2020/01/21 Javascript
通过js实现压缩图片上传功能
2020/02/25 Javascript
[01:45]IMBATV TI4前线报道-选手到达
2014/07/07 DOTA
[01:02:05]LGD vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
使用Python编写提取日志中的中文的脚本的方法
2015/04/30 Python
Python网络编程之TCP与UDP协议套接字用法示例
2018/02/02 Python
Django项目开发中cookies和session的常用操作分析
2018/07/03 Python
详解在Python中以绝对路径或者相对路径导入文件的方法
2019/08/30 Python
numpy ndarray 按条件筛选数组,关联筛选的例子
2019/11/26 Python
TensorFlow中如何确定张量的形状实例
2020/06/23 Python
HTML5之SVG 2D入门6—视窗坐标系与用户坐标系及变换概述
2013/01/30 HTML / CSS
英国花园家具中心:Garden Furniture Centre
2017/08/24 全球购物
伦敦剧院门票:From The Box Office
2018/06/30 全球购物
采用冷却技术的超自然舒适度:GhostBed床垫
2018/09/18 全球购物
Manuka Doctor英国官网:真正的麦卢卡蜂蜜和护肤品
2018/10/26 全球购物
StubHub澳大利亚:购买或出售您的门票
2019/08/01 全球购物
自主招生自荐信怎么写
2015/03/24 职场文书
复兴之路纪录片观后感
2015/06/02 职场文书
python单向链表实例详解
2022/05/25 Python