您好,登录后才能下订单哦!
本篇内容主要讲解“VUE入门学习之如何理解事件处理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“VUE入门学习之如何理解事件处理”吧!
可以用v-on:click="methodName"或者快捷方式 @click="methodName"绑定事件处理函数
@click="methodName()"也可以,@click="methodName"猜测是简写
<div v-on:click="add">{{ count }}</div> <div @click="add">{{ count }}</div>
data() { return { count: 0, }; }, methods: { add() { this.count++; }, },
可以直接在往事件绑定的函数里传参数和$event
<div @click="set(0, $event)">{{ count }}</div>
data() { return { count: 0, }; }, methods: { add() { this.count++; }, set(value, event) { console.log(event); this.count = value; }, },
多个函数直接用逗号分隔,这里即使是没有入参的函数,也要加括号,否则不会执行那个函数
比如<div @click="set(0, $event), log">{{ count }}</div> 只会执行set
<div @click="set(0, $event), log()">{{ count }}</div>
data() { return { count: 0, }; }, methods: { add() { this.count++; }, log() { console.log("log---"); }, set(value, event) { console.log(event); this.count = value; }, },
使用修饰符时,顺序很重要;相应的代码会以同样的顺序产生
<!-- 阻止单击事件继续传播 -->
<a @click.stop="doThis"></a><!-- 提交事件不再重载页面 -->
<form @submit.prevent="onSubmit"></form><!-- 修饰符可以串联 -->
<a @click.stop.prevent="doThat"></a><!-- 只有修饰符 -->
<form @submit.prevent></form><!-- 添加事件监听器时使用事件捕获模式 -->
<!-- 即内部元素触发的事件先在此处理,然后才交由内部元素进行处理 -->
<div @click.capture="doThis">...</div><!-- 只当在 event.target 是当前元素自身时触发处理函数 -->
<!-- 即事件不是从内部元素触发的 -->
<div @click.self="doThat">...</div><!-- 点击事件将只会触发一次 能被用到自定义的组件事件上 -->
<a @click.once="doThis"></a><!-- 滚动事件的默认行为 (即滚动行为) 将会立即触发 -->
<!-- 而不会等待 `onScroll` 完成 -->
<!-- 这其中包含 `event.preventDefault()` 的情况 -->
<!-- 尤其能够提升移动端的性能 -->
<div @scroll.passive="onScroll">...</div>
.enter
.tab
.delete (捕获“删除”和“退格”键)
.esc
.space
.up
.down
.left
.right
<!-- 只有在 `key` 是 `Enter` 时调用 `vm.submit()` -->
<input @keyup.enter="submit" /><!-- 只有在 `key` 是 PageDown时调用 `vm.onPageDown()` -->
<input @keyup.page-down="onPageDown" />
事件触发时修饰键必须处于按下状态
.ctrl
.alt
.shift
.meta
<!-- 按住Alt, 按Enter -->
<input @keyup.alt.enter="clear" /><!-- 按住Ctrl + Click -->
<div @click.ctrl="doSomething">Do something</div>
<!-- 即使 Alt 或 Shift 被一同按下时也会触发 -->
<button @click.ctrl="onClick">A</button><!-- 有且只有 Ctrl 被按下的时候才触发 -->
<button @click.ctrl.exact="onCtrlClick">A</button><!-- 没有任何系统修饰符被按下的时候才触发 -->
<button @click.exact="onClick">A</button>
<button @click.left="log('left cllilck')">鼠标左击</button> <button @click.right="log('right cllilck')">鼠标右击</button> <button @click.middle="log('middle cllilck')">鼠标中击</button>
到此,相信大家对“VUE入门学习之如何理解事件处理”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。