1.监听事件
我们可以使用v-on指令(通常缩写为@符号)来监听DOM事件,并在触发事件时执行一些JavaScript。用法为v-on:clicl="methodName"或者使用快捷方式@click="methodName"。
2.事件处理方法
许多事件处理逻辑会更为负责,所以直接把JavaScript代码卸载v-on指令中是不可行的。因此v-on还可以接收一个需要调用的方法名称。
3.内联处理器中的方法
- 除了直接绑定到一个方法,也可以在内联JavaScript语句中调用方法。
- 有时也需要在内联语句处理器中访问原始的DOM事件,可以用特殊变量$event把它传入方法
4.多事件处理器
事件处理程序中可以有多个方法,这些方法由逗号分隔符分隔。
5.事件修饰符
在事件处理程序中调用event.preventDefault()或者event.stopPropagation()是非常常见的需求。尽管我们可以在方法中轻松实现这点,但更好的方式是:方法只有纯粹的数据逻辑,而不是去处理DOM事件细节。为了解决这个问题,Vue.js为v-on提供了事件修饰符,修饰符是由点开头的指令后缀来表示的:
- .stop:@click.stop="doThis" //阻止单击事件继续传播
- .prevent:@submit.prevent="onSubmit" //提交事件不再重载页面
- .capture:@click.capture="doThis" //添加事件监听器使用事件捕获模式:内部元素触发的事件先在此处理,然后才交由内部元素进行处理
- .self:@click.self="doThat" //只当在 event.target 是当前元素自身时触发处理函数:即事件不是从内部元素触发的
- .once:@click.once="doThis" //点击事件将只会触发一次
- .passive:@scroll.passive="onScorll" //滚动事件的默认行为将会立即触发而不会等待onScroll完成,这其中包含event.preventDefault()的情况
- .passive修饰符尤其能够提升移动端的性能
- 修饰符可以串联也可以只有修饰符不绑定事件名
- 使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生,因此,用v-on:click.prevent.self会阻止所有的点击,而v-on:click.self.prevent只会阻止对元素自身的点击
- 不要把.passive和.prevent一起使用,因为.prevent将会被忽略,同时浏览器可能会展示一个警告,请记住,.passive会告诉浏览器你不想阻止事件的默认行为
6.按键修饰符
在监听键盘事件时,我们经常需要检查详细的按键。Vue允许为v-on或者@在监听键盘事件时添加按键修饰符:
<!-- 只有在 `key` 是 `Enter` 时调用 `vm.submit()` -->
<input @keyup.enter="submit" />
可以直接将KeyboardEvent.key暴露的任意有效按键名转换为kebab-case来作为修饰符:
<!-- 只有在$event.key等于'PageDown'时会调用处理函数 -->
<input @Keyup.page-down="onPageDown" />
6.1按键别名
Vue为最常用的键提供了别名:
- .enter
- .tab
- .delete(捕获“删除”和“退格”键)
- .esc
- .space
- .up
- .down
- .left
- .right
7.系统修饰键
可以用如下修饰符来实现仅在按下相应按键时才触发鼠标或键盘事件的监听器。
- .ctrl
- .alt
- .shift
- .meta 例如:
<!-- Alt + Enter -->
<input @keyup.alt.enter="clear" />
<!-- Ctrl + Click -->
<div @click.ctrl="doSomething">Do something</div>
修饰键与常规按键不同,在和keyup事件一起用时,事件触发时修饰键必须处于按下状态。换句话说,只有在按住ctrl的情况下释放其他按键,才能触发keyup.ctrl。而单单释放ctrl也不会触发事件。
7.1 .exact修饰符
.exact修饰符允许你控制由精确的系统修饰符组合触发的事件。
<!-- 即使 Alt 或 Shift 被一同按下时也会触发 -->
<button @click.ctrl="onClick">A</button>
<!-- 有且只有 Ctrl 被按下的时候才触发 -->
<button @click.ctrl.exact="onCtrlClick">A</button>
<!-- 没有任何系统修饰符被按下的时候才触发 -->
<button @click.exact="onClick">A</button>
7.2鼠标按钮修饰符
- .left
- .right
- .middle 这些修饰符会限制处理函数仅相应特定的鼠标按钮
8.为什么在HTML中监听事件?
你可能注意到这种事件监听方式违背了关注点分离(separation of concern)这个长期以来的优良传统。但不必担心,因为所有的Vue.js事件处理方法和表达式都严格绑定在当前视图的ViewModel上,它不会导致任何维护上的困难。实际上,使用v-on或@有几个好处:
- 1.扫一眼HTML模板便能轻松定位在JavaScript代码里对应的方法
- 2.因为你无须在JavaScript里手动绑定事件,你的ViewModel代码可以是非常纯粹的逻辑,和DOM完全解耦,更易于测试
- 3.当一个ViewModel被销毁时,所有的事件处理器都会自动被删除。无需担心如何清理它们