建设将网站加入受信网站再试,支持wordpress空间,临沂的网站建设,网页地址怎么消除事件修饰符#xff1a;
在处理事件时调用 event.preventDefault() 或 event.stopPropagation() 是很常见的。尽管我们可以直接在方法内调用#xff0c;但如果方法能更专注于数据逻辑而不用去处理 DOM 事件的细节会更好。
为解决这一问题#xff0c;Vue 为 v-on 提供了事件…事件修饰符
在处理事件时调用 event.preventDefault() 或 event.stopPropagation() 是很常见的。尽管我们可以直接在方法内调用但如果方法能更专注于数据逻辑而不用去处理 DOM 事件的细节会更好。
为解决这一问题Vue 为 v-on 提供了事件修饰符。修饰符是用 . 表示的指令后缀包含以下这些
!-- 单击事件将停止传递 --
a click.stopdoThis/a!-- 提交事件将不再重新加载页面,阻止默认事件 --
form submit.preventonSubmit/form!-- 修饰语可以使用链式书写 --
a click.stop.preventdoThat/a!-- 也可以只有修饰符 --
form submit.prevent/form!-- 仅当 event.target 是元素本身时才会触发事件处理器 --
!-- 例如事件处理器不来自子元素 --
div click.selfdoThat.../div
使用修饰符时需要注意调用顺序因为相关代码是以相同的顺序生成的。因此使用 click.prevent.self 会阻止元素及其子元素的所有点击事件的默认行为而 click.self.prevent 则只会阻止对元素本身的点击事件的默认行为。
!-- 添加事件监听器时使用 capture 捕获模式 --
!-- 例如指向内部元素的事件在被内部元素处理前先被外部处理能够改变冒泡事件的触发顺序 --
div click.capturedoThis.../div!-- 点击事件最多被触发一次 --
a click.oncedoThis/a!-- 滚动事件的默认行为 (scrolling) 将立即发生而非等待 onScroll 完成 --
!-- 以防其中包含 event.preventDefault() --
div scroll.passiveonScroll.../div 按键修饰符
在监听键盘事件时我们经常需要检查特定的按键。Vue 允许在 v-on 或 监听按键事件时添加按键修饰符。
!-- 仅在 key 为 Enter 时调用 submit --
input keyup.entersubmit /
你可以直接使用 KeyboardEvent.key 可跳转查看暴露的按键名称作为修饰符但需要转为 kebab-case 形式。
input keyup.page-downonPageDown /
Vue 为一些常用的按键提供了别名
.enter .tab .delete (捕获“Delete”和“Backspace”两个按键) .esc .space .up .down .left .right 系统按键修饰符
你可以使用以下系统按键修饰符来触发鼠标或键盘事件监听器只有当按键被按下时才会触发。
.ctrl .alt .shift .meta
在 Mac 键盘上meta 是 Command 键 (⌘)。在 Windows 键盘上meta 键是 Windows 键 (⊞)。在 Sun 微机系统键盘上meta 是钻石键 (◆)。在某些键盘上特别是 MIT 和 Lisp 机器的键盘及其后代版本的键盘如 Knight 键盘space-cadet 键盘meta 都被标记为“META”。在 Symbolics 键盘上meta 也被标识为“META”或“Meta”。
!-- Alt Enter --
input keyup.alt.enterclear /!-- Ctrl 点击 --
div click.ctrldoSomethingDo something/div请注意系统按键修饰符和常规按键不同。与 keyup 事件一起使用时该按键必须在事件发出时处于按下状态。换句话说keyup.ctrl 只会在你仍然按住 ctrl 但松开了另一个键时被触发。若你单独松开 ctrl 键将不会触发。 .exact 修饰符
.exact 修饰符允许控制触发一个事件所需的确定组合的系统按键修饰符。
!-- 当按下 Ctrl 时即使同时按下 Alt 或 Shift 也会触发 --
button click.ctrlonClickA/button!-- 仅当按下 Ctrl 且未按任何其他键时才会触发 --
button click.ctrl.exactonCtrlClickA/button!-- 仅当没有按下任何系统按键时触发 --
button click.exactonClickA/button鼠标按键修饰符
.left .right .middle 这些修饰符将处理程序限定为由特定鼠标按键触发的事件