( V) G2 k8 T, s3 l! h除了默认设置的核心指令( v-model 和 v-show ), Vue 也允许注册自定义指令。 下面我们注册一个全局指令 v-focus, 该指令的功能是在页面加载时,元素获得焦点: 实例; w: P1 Q" `% T* `$ l
0 h/ q. K* }+ d# c+ N- <div id="app"> e" ~. G m7 H8 F3 g
- <p>页面载入时,input 元素自动获取焦点:</p>1 b: f7 u1 f4 S& m# y1 Q
- <input v-focus>
0 {7 I- x+ s4 e4 V+ }/ m- v* Q - </div>
5 C% r6 C# Z* U5 b: o! P% r* a -
% O# \9 [' I" \1 b* y0 S - <script>
2 {! |* A* P- h2 S6 ^' y& `1 M4 J - // 注册一个全局自定义指令 v-focus1 i% O3 `7 u3 x- Q' F
- Vue.directive('focus', {
3 Z* b! n' Q6 ?7 x - // 当绑定元素插入到 DOM 中。/ E- `! Z7 Y$ s0 p8 j
- inserted: function (el) {, O6 ^' A$ u8 m; L" j! O
- // 聚焦元素
: w! Z' \) g& `* v& M, C. Y1 l - el.focus()& g7 L& U- @9 O* Q$ S, G7 c1 @
- }
7 A* \8 k9 v9 a2 m$ J% R% E2 h - })" v: b, f3 j3 l: I8 R' e- Q
- // 创建根实例
# t5 f( `" i1 ? - new Vue({
: Y% }; g% r% K, |& ` - el: '#app'
8 y6 ? f1 ]+ @# S; h3 `+ Z - })
; M- o7 R& v6 O/ b. t - </script>
复制代码我们也可以在实例使用 directives 选项来注册局部指令,这样指令只能在这个实例中使用: 实例4 Y: f) r# l) X1 Z2 l, @1 \1 ?
! v9 k4 P$ ?$ X) s$ ?6 m) Y- <div id="app">
$ G: F' I% g& k& E - <p>页面载入时,input 元素自动获取焦点:</p>7 z+ q2 S+ V# Q) g0 V! y4 j
- <input v-focus>
- r- q5 h- ?! K) S: w% q! t - </div>
) P: K3 a5 y4 z2 q$ w9 @8 \ - ! j$ G" m( [7 l f! f
- <script>8 I: t" {" L) D* ~$ C3 }1 b9 R% g5 q5 Z
- // 创建根实例
2 n9 e! S& S' Z; d - new Vue({
* w) j" {8 K. U4 h5 f - el: '#app',
2 Q# o# k1 I, x - directives: {+ {. B, J1 H7 I @- d3 L
- // 注册一个局部的自定义指令 v-focus) k0 q. [- U9 k1 ?
- focus: {
. }% _; U# D1 d6 i, O- x% u - // 指令的定义 C* [0 U8 j6 C* @9 X* {4 m9 n' U ?7 w
- inserted: function (el) {9 M) t$ \2 Q# N6 R. v. O0 ~: @
- // 聚焦元素+ `) \, G. w5 i
- el.focus()9 c: m: I# Y7 a1 N6 s2 E
- }
( ]' G& Q- q* ^ }/ c$ d - }
% s4 R& Y. w) m& I3 C5 F. a - }
. U6 u- d( P1 v! e2 L( S - }): N9 N7 q7 v! l a S# c
- </script>
复制代码 钩子钩子函数指令定义函数提供了几个钩子函数(可选): bind: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作。 inserted: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。 update: 被绑定元素所在的模板更新时调用,而不论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新(详细的钩子函数参数见下)。 componentUpdated: 被绑定元素所在模板完成一次更新周期时调用。 unbind: 只调用一次, 指令与元素解绑时调用。 1 \( Z# H5 U) O5 `+ g6 z
钩子函数参数钩子函数的参数有: - el: 指令所绑定的元素,可以用来直接操作 DOM 。
- binding: 一个对象,包含以下属性:
- name: 指令名,不包括 v- 前缀。
- value: 指令的绑定值, 例如: v-my-directive="1 + 1", value 的值是 2。
- oldValue: 指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。
- expression: 绑定值的表达式或变量名。 例如 v-my-directive="1 + 1" , expression 的值是 "1 + 1"。
- arg: 传给指令的参数。例如 v-my-directive:foo, arg 的值是 "foo"。
- modifiers: 一个包含修饰符的对象。 例如: v-my-directive.foo.bar, 修饰符对象 modifiers 的值是 { foo: true, bar: true }。
0 y! F U/ _6 l4 R& o5 y. U
- vnode: Vue 编译生成的虚拟节点。
- oldVnode: 上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。% E* h, w( L4 T7 p; b! |/ ]
以下实例演示了这些参数的使用: 实例' {: O1 ^* r/ U6 H) ]- @7 \* Z
, }3 V3 f# ~3 u5 W* f8 w- <div id="app" v-runoob:hello.a.b="message">5 z7 S+ |, P8 U/ D$ L" r. T3 s
- </div>5 ?# I |8 i# o2 M
- ! I% l7 X* u9 n
- <script>: I H: {/ O/ F# M' y" S8 e% q
- Vue.directive('runoob', {: t- {! Q5 m' e0 e
- bind: function (el, binding, vnode) {0 g% H% w+ P: G% \" U
- var s = JSON.stringify
$ p0 o* l9 C" J2 s - el.innerHTML =! B' _4 @/ p5 R {4 T
- 'name: ' + s(binding.name) + '<br>' +
6 e7 b+ z, I' L; r$ { - 'value: ' + s(binding.value) + '<br>' +* a& d1 `. ~# X; K' E* ~4 |
- 'expression: ' + s(binding.expression) + '<br>' +
; o- O# W4 k5 c' P7 G) Z r- } - 'argument: ' + s(binding.arg) + '<br>' +
) b$ D! `( t! U" p* T - 'modifiers: ' + s(binding.modifiers) + '<br>' +5 y# Y& `+ o* @, s
- 'vnode keys: ' + Object.keys(vnode).join(', ')
1 Q. k( x" ?' g) b# B' w+ N - }
8 G! N. @1 F' b# I8 F, Z& F - })
- p1 d4 |6 _2 a - new Vue({$ c+ o$ B# `2 n
- el: '#app',
+ M& }" F/ f& S( ]/ R - data: {
9 g6 [/ ?/ Q1 d. ?* u3 D4 b - message: '菜鸟教程!'
* w' x, a( l- ?! c2 A - }9 A& _. _6 Y: e& c5 [$ N
- })
" C5 @4 P/ |8 q, ? - </script>
复制代码 有时候我们不需要其他钩子函数,我们可以简写函数,如下格式:
3 v* A9 \* U" V" D( e8 ^, J' E- Vue.directive('runoob', function (el, binding) {5 d% a/ A3 v0 _% U: o
- // 设置指令的背景颜色
# G$ B) e( `0 d2 R2 _2 l1 H8 [ - el.style.backgroundColor = binding.value.color6 }& l' C% n g6 W" A$ Z
- })
复制代码 * j9 Y) L% O8 a- R P, O
# A& }; T& d2 L. d- Y. j
指令函数可接受所有合法的 JavaScript 表达式,以下实例传入了 JavaScript 对象: 实例& N; X1 R3 ^/ e
- a. R: q' a1 A$ i% \: n- <div id="app">5 d# Y. G) K+ ^( y
- <div v-runoob="{ color: 'green', text: '菜鸟教程!' }"></div>
% |4 C3 m. G0 h$ D( p - </div>, d6 V* N2 D, }' {9 `7 Z
-
+ W5 ?/ ~" B$ X, v) I! v2 G% Y - <script>, r. T# R: Z- ?) W9 D
- Vue.directive('runoob', function (el, binding) {
7 C7 ` b! `6 m - // 简写方式设置文本及背景颜色) V2 r* l$ n) u3 q9 Q
- el.innerHTML = binding.value.text
K& l! b5 u4 U+ c3 I - el.style.backgroundColor = binding.value.color
2 h: H. H: M0 l, x - })
8 @4 ^5 r5 n; t1 I9 ~2 W2 I - new Vue({% O4 p$ [% f: R( I( }" q5 K2 S7 N
- el: '#app'! U$ x1 h' l; T* K
- })5 q7 Z4 r; y# r) L3 k2 s3 S: m1 v& r
- </script>
复制代码
+ f5 R7 c2 O6 h& K) w5 l( R
' S A! F1 D( O7 ?
+ F2 j _, T" V/ c/ L/ c |