事件监听可以使用 v-on 指令: v-on
' q3 }: V! P$ A! X, w! J- <div id="app">
0 Q/ a4 ^, z) R4 U# Z6 N - <button v-on:click="counter += 1">增加 1</button>
! J" d" ~5 g6 o5 ~% n( Q1 G - <p>这个按钮被点击了 {{ counter }} 次。</p>% g! {6 F% I9 E+ z
- </div>
, n3 x' Q( {) d -
( D P; y. s1 ~3 @ - <script>
$ u! C! ?7 f* E9 I! P" `# H - new Vue({
8 L7 }% D9 a. E0 c8 _: F$ H - el: '#app',
8 z" Q$ j$ n6 C6 j6 J- Z. d - data: {& Q5 R: j, c' ?' T! e0 X2 W' i9 y
- counter: 0
$ B. a% s _ p# i - }
2 z+ z$ e# d7 U* D* b - })
" l. k& f1 C- P9 [ - </script>
复制代码通常情况下,我们需要使用一个方法来调用 JavaScript 方法。 v-on 可以接收一个定义的方法来调用。 v-on0 f3 s* X' X$ r0 m
- <div id="app">' q' r7 W) F% {7 H) u; N
- <!-- `greet` 是在下面定义的方法名 -->
2 h/ `% l; y" w, l% a- O; O - <button v-on:click="greet">Greet</button>6 Z7 D& d/ Q! E( l( T* I+ L; g
- </div>
7 Q- P2 R% f7 F7 } - 2 ~+ G! T% g. `, e; a' `
- <script>+ ~- O, }; Z2 P1 O6 }! g
- var app = new Vue({
5 L+ A: h" Q# F( \( ]$ Q - el: '#app',
4 k* K* f1 e/ J) A, B - data: {
7 U- O6 S' |7 B - name: 'Vue.js'
0 m2 Q" x8 b$ x, \' B6 [( ^ - },6 Q7 o" Y ?' H+ u2 f
- // 在 `methods` 对象中定义方法
7 ~" }) ~% Z8 K; u0 I - methods: {! C% L- b4 Q$ i
- greet: function (event) {1 Q; F# u( u6 M7 `* o0 {' A
- // `this` 在方法里指当前 Vue 实例" o- S5 ]8 I! j% A% X6 n y, O
- alert('Hello ' + this.name + '!')
# Q6 ^$ x7 d# I o: s - // `event` 是原生 DOM 事件
9 Y" f6 |4 E! H; q - if (event) {; W7 m' f: b) T! O3 _; } v9 E0 o
- alert(event.target.tagName): @! o1 A1 [1 L
- }' t+ l' P! N! t* g0 c" U8 ^- O
- }# H+ q" ~# r1 l% q/ P$ E
- }
& ]( @8 S2 {. a$ r' t - })0 T+ p+ I0 l* ~# x
- // 也可以用 JavaScript 直接调用方法
* G9 R+ i |$ j: P+ ]* v - app.greet() // -> 'Hello Vue.js!'9 s6 Z3 m: i8 W, b
- </script>
复制代码除了直接绑定到一个方法,也可以用内联 JavaScript 语句: v-on6 n7 f: U$ m& y6 W. A# P4 `: D! P! o
- <div id="app">; D& | v0 @1 d" d; z
- <button v-on:click="say('hi')">Say hi</button>
: x$ O3 g3 R( [7 E - <button v-on:click="say('what')">Say what</button>
# X: X: o0 J' Z* b, @: w - </div>- o! ]: s: ?2 f' C# P) |& ]; Q# x
- 3 h+ Y: f7 H" T5 i# a
- <script>1 n3 |+ @- A! y
- new Vue({ g5 v" t; o' C7 Z2 v! t+ c( h
- el: '#app',
0 h' ]9 Y5 J3 R% L3 P. L) o8 } - methods: {
! E3 `! O2 [. ?# ?5 J - say: function (message) {
L7 Z8 v/ v" Q2 c - alert(message)
$ I9 B1 K) a$ i3 ?" D - }
, L3 x) ^6 o5 F9 j5 D - }
; K- O% y6 ?" F5 D( p6 y9 W - })) }* w- b# Q* Y$ L6 `
- </script>
复制代码 事件修饰符Vue.js 为 v-on 提供了事件修饰符来处理 DOM 事件细节,如:event.preventDefault() 或 event.stopPropagation()。 Vue.js通过由点(.)表示的指令后缀来调用修饰符。 - .stop
- .prevent
- .capture
- .self
- .once/ u& [, ?$ W8 r. {" h, b5 |
- <!-- 阻止单击事件冒泡 -->
( K" y+ I0 A6 j* y7 o - <a v-on:click.stop="doThis"></a>) s4 u$ P& ^; F" r
- <!-- 提交事件不再重载页面 -->
9 [4 ?( }- @5 C$ d& ` - <form v-on:submit.prevent="onSubmit"></form>6 r* Z6 @/ ]% Q k4 C; A% l# w
- <!-- 修饰符可以串联 -->
" O+ a* i& n2 l l - <a v-on:click.stop.prevent="doThat"></a>2 Q) i* K4 u0 h& w" x. h
- <!-- 只有修饰符 -->
2 o6 p% X* f, F; ~9 T: i, R - <form v-on:submit.prevent></form>! F+ t; K& ]* b
- <!-- 添加事件侦听器时使用事件捕获模式 -->
& f! u: R& s$ s - <div v-on:click.capture="doThis">...</div>/ t! [0 x& H3 F! D9 u( Q& v! Z
- <!-- 只当事件在该元素本身(而不是子元素)触发时触发回调 -->! B; ]$ i% U N! I2 b
- <div v-on:click.self="doThat">...</div>% Z9 _2 e' w- N3 m; J: i* N" a
$ _/ s/ B2 [$ S/ W/ J; e- <!-- click 事件只能点击一次,2.1.4版本新增 -->$ d' k ?6 `( A" [7 i$ \$ v* S
- <a v-on:click.once="doThis"></a>
复制代码 按键修饰符Vue 允许为 v-on 在监听键盘事件时添加按键修饰符: - <!-- 只有在 keyCode 是 13 时调用 vm.submit() -->
7 \& o, A$ H" |1 K, y - <input v-on:keyup.13="submit">
复制代码 记住所有的 keyCode 比较困难,所以 Vue 为最常用的按键提供了别名:
: D6 ^* K/ G' D, q' ^1 V: \- <!-- 同上 -->
. }4 W2 {6 W# y$ U - <input v-on:keyup.enter="submit">
# G9 u* C9 {0 l! h - <!-- 缩写语法 -->
. v% r+ ]: V' ^$ h - <input @keyup.enter="submit">
复制代码全部的按键别名: - .enter
- .tab
- .delete (捕获 "删除" 和 "退格" 键)
- .esc
- .space
- .up
- .down
- .left
- .right
- .ctrl
- .alt
- .shift
- .meta
1 @/ D9 I8 q% T) {; ~* o. i
实例
6 n7 A' O" Z* @ L- <p><!-- Alt + C -->
! j l8 O& C: P, v# D, i* m5 z - <input @keyup.alt.67="clear">7 V% e$ R. c0 o, V
- <!-- Ctrl + Click -->% m( c8 C/ f2 U$ |1 J% E: C
- <div @click.ctrl="doSomething">Do something</div>
复制代码 computed 对象内的方法如果在初始化时绑定到元素上的事件会先执行一次这个方法 ,而 methods 内的方法则不会;例如以下实例初始化时会自动执行一遍 name1 和 greet 这两个方法:" R/ s, T6 y6 c% E9 ~3 ?
- var app = new Vue({
+ d1 P0 k7 z; n3 w; ]: r/ F - el: '#app',& Z* f3 Q# o) |9 h" I. U
- data: {
$ C+ t2 Z1 W4 E% ?4 Z9 ? - name: 'Vue.js'
3 ?) W$ V: r9 S - },. X4 `( i, w$ x# k4 y9 \, H$ A
- // 在 `methods` 对象中定义方法+ q! B! M) P0 D' G
- computed: { $ v! s! l% E& H3 D+ n7 C3 Y' ]
- name1: function(){ alert('222') },
8 S: _8 p) E# D( U- u/ c# X& L! q - greet: function (event) {$ Q8 P, p& P/ u6 p+ l; o
- // `this` 在方法里指当前 Vue 实例
2 F9 `5 W; ~* R% c/ F - alert('Hello ' + this.name + '!')
' k& H7 `6 B6 h" ?9 G - // `event` 是原生 DOM 事件5 K( C% p9 `1 h A3 j" ~1 F0 e B
- if (event) {
5 L, B) }$ p) F7 i! h ~* Y; K4 u - alert(event.target.tagName)& p' f H/ l8 ]% R9 c) H2 {8 `. b7 t
- }/ R7 }& x$ x y } _' D" ^& [, J
- }) i; N" M' r% j0 T/ y' \; B
- }
9 A6 k$ Z9 l9 p - })5 m5 v& u. J( J& z! v$ o4 q
- // 也可以用 JavaScript 直接调用方法
复制代码
7 m8 S5 D5 Q- e8 o H& f& j8 N% u+ l' z. }8 a
) X! C+ S% I, W* D$ _1 s6 O
1 a- P' v) J! m$ s7 i% g% n/ l
; _. `9 S; v) n8 R8 h0 t( s# O N- W3 o9 @0 `8 W* M" d
|