一、什么是指令?vue
指令一般以"v-"做为前缀, 以方便Vue知道你在使用一种特殊的标记。
除了 Vue 核心携带着的一些默认指令(v-model 和 v-show)以外,
Vue 还容许你注册本身的自定义指令。某些状况下,仍是须要对普通元素进行一些底层 DOM 访问,
这也是自定义指令仍然有其使用场景之处。node
二、全局指令:express
当页面加载时,元素将获取焦点,事实上,在访问页面时,若是你尚未点击任何地方,上面的输入框如今应该处于获取焦点的状态。如今让咱们构建指令以完成此效果:函数
<template> <div class="parent"> <input v-focus> </div> </template>
import Vue from 'vue' import cnChildren from './children' // 注册一个名为 `v-focus` 的全局自定义指令 Vue.directive('focus', { // 当绑定的元素插入到 DOM 时调用此函数…… inserted: function (el) { // 元素调用 focus 获取焦点 el.focus() } });
若是你想要注册一个局部指令,也能够经过设置组件的 directives 选项:code
directives: { focus: { // 指令定义对象 inserted: function (el) { el.focus() } } }
咱们有几个可用的钩子:component
每一个钩子能够选择一些参数。对象
binding:一个对象,包含如下属性:ip
一、name:指令的名称,不包括 v- 前缀。 二、value:向指令传入的值。例如,在 v-my-directive="1 + 1" 中,传入的值是 2。 三、oldValue:以前的值,只在 update 和 componentUpdated 钩子函数中可用。不管值是否发生变化,均可以使用。 四、expression:指令绑定的表达式(expression),以字符串格式。例如,在 v-my-directive="1 + 1" 中,表达式是 "1 + 1"。 五、arg:向指令传入的参数,若是有的话。例如,在 v-my-directive:foo 中,参数是 "foo"。 六、modifiers:一个对象,包含修饰符,若是有的话。例如,在 v-my-directive.foo.bar 中,修饰符是 { foo: true, bar: true }。
除了 el 以外的其余参数,都应该是只读的,而且永远不要去修改它们。 字符串
三、自定义指令示例input
若是指令须要多个值,你还能够向指令传入 JavaScript 对象字面量(object literal)。记住,指令可以接收全部有效的 JavaScript 表达式。
<div v-demo="{ color: 'white', text: 'hello!' }"></div>
Vue.directive('demo', function (el, binding) { console.log(binding.value.color) // => "white" console.log(binding.value.text) // => "hello!" })