vue(2)
1. 键值修饰符
1.1 vue
允许v-on
在监听键盘事件时,添加关键修饰符:
1 | <!--只有在keyCode在等于13时调用submit()方法--> |
1.2 全部按键别名:
.enter
.tab
.delete
(捕获 “删除” 和 “退格” 键).esc
.space
.up
.down
.left
.right
- 以下是2.1.0版本新增的
.ctrl
.alt
.shift
.meta
1.3 自定义键盘修饰符
1 | // 1.x版本中(了解) |
使用自定义键盘修饰符
1 | <input type='text' v-model="name" @keyup.f2="add"> |
2. 过滤器
概念:Vue.js
允许你自定义过滤器,可被用作一些常见的文本格式化。过滤器可以用在两个地方:mustache 插值和 v-bind 表达式。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符指示;
2.1 私有过滤器
- HTML元素:
1 | <td>{{item.createTime | dataFormat('yyyy-mm-dd')}}</td> |
- 私有
filters
定义方式:
1 | filters: { // 私有局部过滤器,只能在 当前 VM 对象所控制的 View 区域进行使用 |
使用ES6中的字符串新方法 String.prototype.padStart(maxLength, fillString=’’) 或 String.prototype.padEnd(maxLength, fillString=’’)来填充字符串;
2.2 全局过滤器
1 | // 定义一个全局过滤器 |
注意:当有局部和全局两个名称相同的过滤器时候,会以就近原则进行调用,即:局部过滤器优先于全局过滤器被调用!
3. vue.js
自定义指令
除了默认设置的核心指令( v-model 和 v-show ), Vue 也允许注册自定义指令。
3.1 自定义全局指令
1 | // Vue.directive(指令名称, 对象) 定义全局的指令,eg: v-focus |
3.2 在实例中使用 directives 选项来注册局部指令
1 | directives: { |
1 | <!--vue.js的使用--> |
3.3 指令函数可接受所有合法的 JavaScript 表达式
定义指令函数:
1 | Vue.directive('my-style', function (el, binding){ |
传入了 JavaScript 对象:
1 | <p v-my-style="{fontSize: '30', text: '我是文本', color: 'blue'}"></p> |
4. 钩子
4.1 钩子函数
指令定义函数提供了几个钩子函数(可选):
bind
: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作。inserted
: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。update
: 被绑定元素所在的模板更新时调用,而不论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新(详细的钩子函数参数见下)。componentUpdated
: 被绑定元素所在模板完成一次更新周期时调用。unbind
: 只调用一次, 指令与元素解绑时调用。
4.2 钩子函数参数
钩子函数的参数有:
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 }
。
- name: 指令名,不包括
vnode: Vue 编译生成的虚拟节点。
oldVnode: 上一个虚拟节点,仅在
update
和componentUpdated
钩子中可用。