In Vue verarbeiten Ereignismodifikatoren die Details vieler DOM-Ereignisse, sodass wir nicht mehr viel Zeit mit der Bearbeitung dieser lästigen Dinge verbringen müssen, sondern uns mehr darauf konzentrieren können die logische Abarbeitung des Programms. (Teilen von Lernvideos: vue-Video-Tutorial)
Die wichtigsten Ereignismodifikatoren in Vue sind:
.stop
.stop
:等同于JavaScript中的event.stopPropagation()
,防止事件冒泡.prevent
:等同于JavaScript中的event.preventDefault()
,防止执行预设的行为(如果事件可取消,则取消该事件,而不停止事件的进一步传播).capture
:与事件冒泡的方向相反,事件捕获由外到内.self
:只会触发自己范围内的事件,不包含子元素.once
:只会触发一次
接下来,咱们通过一些简单的示例来看看事件修饰符起的作用。
冒泡事件:嵌套两三层父子关系,然后所有都有点击事件,点击子节点,就会触发从内至外 子节点->父节点的点击事件
<!-- HTML --> <div> <div> <div> <button>点击我(^_^)</button> </div> </div> <p>{{ message }}</p> </div> let app = new Vue({ el: '#app', data () { return { message: '测试冒泡事件' } }, methods: { inner: function () { this.message = 'inner: 这是最里面的Button' }, middle: function () { this.message = 'middle: 这是中间的Div' }, outer: function () { this.message = 'outer: 这是外面的Div' } } })
整个事件示意图如下:
防止冒泡事件的写法是:在点击上加上.stop
相当于在每个方法中调用了等同于event.stopPropagation()
,点击子节点不会捕获到父节点的事件
<!-- HTML --> <div id="app"> <div class="outeer" @click.stop="outer"> <div class="middle" @click.stop="middle"> <button @click.stop="inner">点击我(^_^)</button> </div> </div> </div>
这个时候,点击button时,并不会捕获到div.middle和div.outer上的事件:
.prevent
等同于JavaScript的event.preventDefault()
,用于取消默认事件。比如我们页面的<a href="#">
标签,当用户点击时,通常在浏览器的网址列出#
:
在JavaScript中,常常使用event.preventDefault()
来防止浏览器的网址中出现#。在Vue中,可以使用事件修饰符.prevent
来取消默认事件。这个时候,点击链接之后,浏览器的网址中再也不会出现#。
<div id="app"> <a href="#" @click.prevent="prompt">点击我(^_^)</a> <p>{{ message }}</p> </div> let app = new Vue({ el: '#app', data () { return { message: '我是一个文本信息' } }, methods: { prompt: function (e) { this.message = location.href } } })
捕获事件:嵌套两三层父子关系,然后所有都有点击事件,点击子节点,就会触发从外至内 父节点->子节点的点击事件
.capture
修饰符和.stop
刚好相反。.stop
是防止事件冒泡,而.capture
类似JavaScript的事件捕获,是由外到内的。如下图所示:
用到我们的Vue的事件修饰符中:
<!-- HTML --> <div id="app"> <div class="outeer" @click.capture="outer"> <div class="middle" @click.capture="middle"> <button @click.capture="inner">点击我(^_^)</button> </div> </div> <p>{{ message }}</p> </div> let app = new Vue({ el: '#app', data () { return { message: '事件捕获' } }, methods: { inner: function () { this.message = 'inner: 这是最里面的Button' alert(this.message) }, middle: function () { this.message = 'middle: 这是中间的Div' alert(this.message) }, outer: function () { this.message = 'outer: 这是外面的Div' alert(this.message) } } })
看到的行为如下:
修饰符.self
只会触发自己范围内的事件,不会包含子元素。
<!-- HTML --> <div id="app"> <div class="outer" @click.self="outer"> <div class="middle" @click.self="middle"> <button @click="inner">点击我(^_^)</button> </div> </div> <p>{{ message }}</p> </div> let app = new Vue({ el: '#app', data () { return { message: '修饰符:.self' } }, methods: { inner: function () { this.message = 'inner: 这是最里面的Button' alert(this.message) }, middle: function () { this.message = 'middle: 这是中间的Div' alert(this.message) }, outer: function () { this.message = 'outer: 这是外面的Div' alert(this.message) } } })
咱们分别点击div.outer
、div.middle
和button
,在这几个元素上都绑定了click事件,并且添加了.self修饰符:
还记得我们以前使用Vue写了一个计数器,点击+
就会加1,不断点击就会不断累加,反则点击-
就会减1,不断点击就会不断减少。
<div id="app"> <button v-on:click="increase">+</button> <span>{{ count }}</span> <button v-on:click="reduce">-</button> </div> let app = new Vue({ el: '#app', methods: { increase: function() { this.count++ }, reduce: function() { this.count-- } }, data: { count: 0 } })
如果我们在@click
事件上添加.once
: entspricht event.stopPropagation( in JavaScript) )
, verhindert das Sprudeln von Ereignissen
.prevent
: Entspricht event.preventDefault()
in JavaScript und verhindert die Ausführung des voreingestellten Verhaltens ( Wenn das Ereignis stornierbar ist, stornieren Sie das Ereignis, ohne die weitere Ausbreitung des Ereignisses zu stoppen)
.capture
: In der entgegengesetzten Richtung der Ereignissprudelung erfolgt die Ereigniserfassung von außen nach innen< /li>.self
🎜: Nur Ereignisse innerhalb seines eigenen Bereichs werden ausgelöst, ausgenommen untergeordnete Elemente🎜🎜🎜.once
🎜: Nur es wird ausgelöst einmal ausgelöst werden🎜🎜Als nächstes schauen wir uns die Rolle von Ereignismodifikatoren anhand einiger einfacher Beispiele an. 🎜🎜.stop verhindert, dass Ereignisse sprudeln 🎜
🎜Blasenereignisse: Verschachteln Sie zwei oder drei Ebenen von Eltern-Kind-Beziehungen, und wenn Sie auf einen untergeordneten Knoten klicken, werden untergeordnete Knoten von innen ausgelöst nach außen - >Klickereignis des übergeordneten Knotens🎜🎜🎜🎜Das Diagramm der gesamten Veranstaltung sieht wie folgt aus: 🎜🎜🎜🎜Die Möglichkeit, Bubbling-Ereignisse zu verhindern, ist: Das Hinzufügen von<div id="app"> <button @click.once="increase">+</button> <span>{{ count }}</span> <button @click.once="decrease">-</button> </div>Nach dem Login kopieren.stop
zum Klick entspricht dem Aufruf des Äquivalents vonevent.stopPropagation in jeder Methode ()
: Wenn Sie auf den untergeordneten Knoten klicken, wird das Ereignis des übergeordneten Knotens nicht erfasst🎜🎜Zu diesem Zeitpunkt werden beim Klicken auf die Schaltfläche die Ereignisse auf div.middle und div.outer erfasst wird nicht erfasst:🎜🎜🎜<div id="app"> <button @keyup.enter="enter" @keyup.tab="tab" @keyup.delete="delete1" @keyup.esc="esc" @keyup.space="space" @keyup.up="up" @keyup.down="down" @keyup.left="left" @keyup.right="right">{{ message }}</button> <p>{{ message }}</p> </div> let app = new Vue({ el: '#app', data () { return { message: '将光标置于按钮上后,按下键盘上不同的按键,会有不同的效果' } }, methods: { enter: function (){ this.message = '你按了回车键:enter' }, tab: function (){ this.message = '你按了tab键: tab' }, delete1: function (){ this.message = '你按了删除键: delete' }, esc: function (){ this.message = '你按了取消键: esc' }, space: function (){ this.message = '你按了空格键:space' }, up: function (){ this.message = '你按了向上键:up' }, down: function (){ this.message = '你按了向下键:down' }, left: function (){ this.message = '你按了向左键:left' }, right: function (){ this.message = '你按了向右键:right' } } })Nach dem Login kopierenNach dem Login kopieren🎜.preventcancel Standardereignis 🎜
🎜.prevent
entspricht JavaScriptsevent.preventDefault()
, das zum Abbrechen des Standardereignisses verwendet wird Ereignis. Wenn der Benutzer beispielsweise auf unserer Seite auf das Tag<a href="#">
klickt, wird#
normalerweise in der URL des Browsers aufgeführt: 🎜🎜🎜🎜In JavaScript ist es soevent.preventDefault()
wird häufig verwendet, um zu verhindern, dass # in der URL des Browsers erscheint. In Vue können Sie den Ereignismodifikator.prevent
verwenden, um das Standardereignis abzubrechen. Zu diesem Zeitpunkt wird # nach dem Klicken auf den Link nicht mehr in der URL des Browsers angezeigt. 🎜🎜🎜< h3>🎜.capture Capture-Ereignis🎜🎜Capture-Ereignis: Verschachteln Sie zwei oder drei Ebenen von Eltern-Kind-Beziehungen, und klicken Sie dann auf einen untergeordneten Knoten, um den übergeordneten Knoten->untergeordneten Knoten von außen auszulösen nach innen. Click-Ereignis 🎜🎜<!-- HTML --> <div id="app"> <input type="text" v-on:keydown.f5="prompt()"> </div> Vue.config.keyCodes.f5 = 116; let app = new Vue({ el: '#app', methods: { prompt: function() { alert('我是 F5!'); } } });Nach dem Login kopierenNach dem Login kopieren.capture
Modifikator ist genau das Gegenteil von.stop
..stop
verhindert das Sprudeln von Ereignissen, während.capture
der Ereigniserfassung von JavaScript ähnelt, die von außen nach innen erfolgt. Wie im Bild unten gezeigt: 🎜🎜🎜🎜 Nutzen Sie unsere Im Ereignismodifikator von Vue: 🎜rrreee🎜Das Verhalten, das Sie sehen, ist wie folgt: 🎜🎜🎜🎜.self🎜
🎜Der Modifikator.self
löst nur Ereignisse innerhalb seines eigenen Bereichs aus und schließt keine untergeordneten Elemente ein Element. 🎜rrreee🎜Wir klicken jeweils aufdiv.outer
,div.middle
und klicken auf Ereignisse, die an diese Elemente gebunden sind .self-Modifikator: 🎜🎜🎜< h3>🎜.once führt nur einen Klick aus🎜🎜Ich erinnere mich noch daran, dass wir zuvor mit Vue einen Zähler geschrieben haben. Wenn Sie auf+
klicken, wird 1 hinzugefügt, und wenn Sie weiter klicken, wird es fortgesetzt Akkumulieren, andernfalls klicken Sie auf-
und der Wert verringert sich um 1. Wenn Sie weiter klicken, verringert sich der Wert weiter. 🎜rrreee🎜🎜🎜Wenn wir auf dem@click
sind Ereignis Fügen Sie den Modifikator.once
hinzu, damit er nur einmal ausgeführt wird, wenn auf die Schaltfläche geklickt wird. 🎜🎜rrreee🎜🎜🎜🎜🎜Demo-Adresse: https://codepen.io/airen/pen/dVQoRN🎜
在JavaScript事件中除了前面所说的事件,还有键盘事件,也经常需要监测常见的键值。在Vue中允许v-on
在监听键盘事件时添加关键修饰符。记住所有的keyCode
比较困难,所以Vue为最常用的键盘事件提供了别名:
.enter
:回车键.tab
:制表键.delete
:含delete
和backspace
键.esc
:返回键.space
: 空格键.up
:向上键.down
:向下键.left
:向左键.right
:向右键<div id="app"> <button @keyup.enter="enter" @keyup.tab="tab" @keyup.delete="delete1" @keyup.esc="esc" @keyup.space="space" @keyup.up="up" @keyup.down="down" @keyup.left="left" @keyup.right="right">{{ message }}</button> <p>{{ message }}</p> </div> let app = new Vue({ el: '#app', data () { return { message: '将光标置于按钮上后,按下键盘上不同的按键,会有不同的效果' } }, methods: { enter: function (){ this.message = '你按了回车键:enter' }, tab: function (){ this.message = '你按了tab键: tab' }, delete1: function (){ this.message = '你按了删除键: delete' }, esc: function (){ this.message = '你按了取消键: esc' }, space: function (){ this.message = '你按了空格键:space' }, up: function (){ this.message = '你按了向上键:up' }, down: function (){ this.message = '你按了向下键:down' }, left: function (){ this.message = '你按了向左键:left' }, right: function (){ this.message = '你按了向右键:right' } } })
当你把鼠标移动按钮上,然后按下不同的键盘,将会监听到对应的键盘事件:
演示demo地址::https://codepen.io/airen/pen/RLqPYx
鼠标修饰符用来限制处理程序监听特定的滑鼠按键。常见的有:
.left
:鼠标左键.middle
:鼠标中间滚轮.right
:鼠标右键可以用如下修饰符开启鼠标或键盘事件监听,使在按键按下时发生响应:
.ctrl
.alt
.shift
.meta
在Vue中可以通过config.keyCodes
自定义按键修饰符别名。例如,由于预先定义了keycode 116
(即F5
)的别名为f5
,因此在文字输入框中按下F5
,会触发prompt
方法,出现alert
。
<!-- HTML --> <div id="app"> <input type="text" v-on:keydown.f5="prompt()"> </div> Vue.config.keyCodes.f5 = 116; let app = new Vue({ el: '#app', methods: { prompt: function() { alert('我是 F5!'); } } });
在Vue中,使用v-on
来给元素绑定事件,而为了更好的处理逻辑方面的事物,Vue提供了一个methods
。在methods
中定义一些方法,这些方法可以帮助我们处理一些逻辑方面的事情。而在这篇文章中,我们主要介绍了一些事件的修饰符,比如常见的阻止事件冒泡,键盘修饰符等。除此之外,还提供了config.keyCodes
提供自定义按键修饰符别名。
Das obige ist der detaillierte Inhalt vonDetailliertes Beispiel für Ereignismodifikatoren in Vue. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!