使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生。因此,用 v-on:click.prevent.self 会阻止所有的点击,而 v-on:click.self.prevent 只会阻止对元素自身的点击。
不要把 .passive 和 .prevent 一起使用,因为 .prevent 将会被忽略,同时浏览器可能会向你展示一个警告。.passive 会告诉浏览器你不想阻止事件的默认行为。、
事件修饰符
.stop 阻止事件传播(阻止冒泡)
.self 只在event.target是当前元素的时候
.once 只触发一次
.prevent 取消事件默认
.capture 使用事件捕获模式,即元素自身触发的事件先在此处处理,然后才交由内部元素进行处理
.passive 告诉浏览器你不想阻止事件的默认行为 (滚动行为 .passive 修饰符尤其能够提升移动端的性能)
按键修饰符
Vue 允许为 v-on 在监听键盘事件时添加按键修饰符:
<input v-on:keyup.13="submit">
或者
<input @keyup.enter="submit">
按键码
.enter
.tab
.delete (捕获“删除”和“退格”键)
.esc
.space
.up
.down
.left
.right
系统修饰键
.ctrl
.alt
.shift
.meta
(1) .lazy
默认同步更新的,如果添加了lazy的话,等待光标离开的时候才会去同步更新数据
<input v-model.lazy="message">
(1) .number
如果无法被parseFloat解析的话,原样输出,否则显示解析后的结果
<input v-model.number="message">
(1) .trim
去掉前后空格
<input v-model.trim="message">
.exact修饰符 2.5.0新增
.exact 修饰符允许控制由精确的系统修饰符组合触发的事件。
即使 Alt 或 Shift 被一同按下时也会触发
<button v-on:click.ctrl="onClick">A</button>
有且只有 Ctrl 被按下的时候才触发
<button v-on:click.ctrl.exact="onCtrlClick">A</button>
没有任何系统修饰符被按下的时候才触发
<button v-on:click.exact="onClick">A</button>