阅读目录

1.理解VUE中的自定义指令

默认核心指令有 (v-model 和 v-show), 但是有时候我们需要用到自定义指令,在vue中,代码复用主要形式和抽象是组件,但是在有的情况下,我们仍然需要对DOM元素进行底层操作,所以这个时候我们需要用到自定义指令。

比如下面的一个input框,当页面加载时,元素将获得焦点,我们还没有点击input框,input就获得焦点了,如下demo代码:

<!DOCTYPE html>
<html>
<head>
<title>演示Vue</title>
<style> </style>
</head>
<body>
<div id='demo'>
<input v-focus>
</div>
</body>
<script src="./vue.js"></script>
<script type="text/javascript"> // 注册一个全局定义指令 v-focus
Vue.directive('focus', { // 绑定元素插入到DOM 中
inserted: function (el) {
// 聚焦元素
el.focus()
}
})
new Vue({
el: '#demo'
})
</script>
</html>

查看效果

上面的是全局定义指令 v-foucs, 当然我们也可以局部定义,如下代码:

<!DOCTYPE html>
<html>
<head>
<title>演示Vue</title>
<style> </style>
</head>
<body>
<div id='demo'>
<input v-focus>
</div>
</body>
<script src="./vue.js"></script>
<script type="text/javascript">
new Vue({
el: '#demo',
directives: {
focus: {
// 指令的定义
inserted: function (el) {
// 聚焦元素
el.focus()
}
}
}
})
</script>
</html>

查看效果

然后我们就可以在任何input元素框或者textarea使用 v-focus 了,如下代码:

<input v-focus />

2. 指令定义函数提供了如下几个钩子函数(根据VUE教程来):
bind: 只调用一次,指令第一次绑定到元素时调用,也就是说初始化时候调用一次。
inserted: 被绑定元素插入父节点时调用(父节点需要存在才会调用)。
update: 被绑定元素所在的模板更新时调用(通过比较更新前后的绑定值)。
componentUpdated: 被绑定元素所在模板完成一次更新周期时调用。
unbind: 指令与元素解绑时调用,只调用一次,和bind对应。

上面几个钩子函数有如下参数 (el, binding, vnode, oldVnode)
el: 指令所绑定的元素,可用来直接操作DOM。
binding: {Object} obj有如下属性:
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 }。

vnode: Vue编译生成的虚拟节点。
oldVnode: 上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。

注意: 除了 el 之外,其它参数都应该是只读的,尽量不要修改他们。如果需要在钩子之间共享数据,建议通过元素的 dataset 来进行。

如下demo代码:

<!DOCTYPE html>
<html>
<head>
<title>演示Vue</title>
<style> </style>
</head>
<body>
<div id='demo' v-demo:hello.a.b='message'> </div>
</body>
<script src="./vue.js"></script>
<script type="text/javascript">
Vue.directive('demo', {
bind: function(el, binding, vnode) {
var s = JSON.stringify;
el.innerHTML =
'name: ' + s(binding.name) + '<br/>' +
'value: ' + s(binding.value) + '<br/>' +
'expression: ' + s(binding.expression) + '<br/>' +
'argument: ' + s(binding.arg) + '<br/>' +
'modifiers: ' + s(binding.modifiers) + '<br/>' +
'vnode: ' + Object.keys(vnode).join(', ')
}
})
new Vue({
el: '#demo',
data: {
message: 'hello!'
}
})
</script>
</html>

查看效果

对象字面量
如果指令需要多个值,可以传入一个 JavaScript 对象字面量。
如下代码:

<!DOCTYPE html>
<html>
<head>
<title>演示Vue</title>
<style> </style>
</head>
<body>
<div id='demo' v-demo="{ color: 'white', text: 'hello!' }"> </div>
</body>
<script src="./vue.js"></script> <script type="text/javascript">
Vue.directive('demo', function (el, binding) {
console.log(binding.value.color) // => "white"
console.log(binding.value.text) // => "hello!"
})
new Vue({
el: '#demo'
})
</script>
</html>

查看效果

在控制台可以看到输出了字符串了。

2. Vue.js自定义指令的用途。
上面是教程中的一些demo,但是在实际当中我们需要用到什么地方呢?我们可以预想到可以使用到预加载数据的地方,比如预加载图片,由于图片加载需要一些时间,因此我们先加载一张占位符图片,
等图片真正加载完成时候,才加载真正的图片,这样的用户体验效果更能更好点。下面是使用vue自定义指令来实现这个功能,代码如下:

<!DOCTYPE html>
<html>
<head>
<title>演示Vue</title>
<style>
img { width: 180px; height: 180px; overflow: hidden;}
</style>
</head>
<body>
<div id='demo'>
<img v-for='item in list' v-img='item.url'/>
</div>
</body>
<script src="./vue.js"></script> <script type="text/javascript">
Vue.directive('img', {
inserted: function(el, binding) {
console.log(el)
// 下面使用一张背景颜色来演示一下,
var color = Math.floor(Math.random()*1000000);
el.style.backgroundColor = '#' + color; // 随机的背景颜色 var img = new Image();
img.src = binding.value;
img.onload = function() {
el.style.backgroundImage = 'url(' + binding.value + ')';
}
}
});
new Vue({
el: '#demo',
data: {
list: [
{
url: 'http://img.alicdn.com/imgextra/i3/730692984/TB2.dQMdxXkpuFjy0FiXXbUfFXa_!!730692984-0-beehive-scenes.jpg_180x180q70'
},
{
url: 'http://img.alicdn.com/imgextra/i2/730692984/TB239AJdw0kpuFjSspdXXX4YXXa_!!730692984-0-beehive-scenes.jpg_180x180q70'
},
{
url: 'http://img.alicdn.com/imgextra/i4/730692984/TB29TsZdrVkpuFjSspcXXbSMVXa_!!730692984-0-beehive-scenes.jpg_180x180q70'
}
]
}
})
</script>
</html>

查看效果

如上演示可以看到,刚开始载入页面的时候,有那么一瞬间先是背景颜色 最后是图片,这里只是简单的演示一下,在实际使用中,我们可以先放一张预加载的图片,当真正图片加载完成的时候,才显示真正的图片,省的在图片未加载完成的时候,背景图片是空白的效果就不是很好了。

VUE2第五天学习---自定义指令的更多相关文章

  1. VUE2 第五天学习--过渡效果

    阅读目录 1.理解VUE---过渡效果 回到顶部 1.理解VUE---过渡效果 1. 过渡的-css-类名会有4个(css) 类名在 enter/leave 在过渡中切换.1. v-enter: 进入 ...

  2. angualar入门学习-- 自定义指令 指令编译执行过程

    3个阶段: 一.加载阶段 加载angular.js的源码,找到ng-app确定应用边界范围. 二.编译阶段 compile 查找所有指令,保存在一个列表中 对所有指令按优先级(property属性值) ...

  3. angualar入门学习-- 自定义指令 认识属性

    个AngularJS指令在HTML代码中可以有四种表现形式: 1.作为一个新的HTML元素来使用 2.作为一个元素的属性来使用 3.作为一个元素的类来使用 4.作为注释来使用 一.创建指令 angul ...

  4. vue2.0自定义指令

    前面一片文章说了vue2.0过滤器,其实自定义指令跟过滤器非常相似,单就定义方式而言,其与过滤器完全一致,分为局部指令,和全局指令.不过就是filter改为directive的区别. 过滤器一般用于对 ...

  5. 带你走近AngularJS - 创建自定义指令

    带你走近AngularJS系列: 带你走近AngularJS - 基本功能介绍 带你走近AngularJS - 体验指令实例 带你走近AngularJS - 创建自定义指令 ------------- ...

  6. 带你走近AngularJS 之创建自定义指令

    带你走近AngularJS 之创建自定义指令 为什么使用AngularJS 指令? 使用过 AngularJS 的朋友应该最感兴趣的是它的指令.现今市场上的前端框架也只有AngularJS 拥有自定义 ...

  7. vue3.0自定义指令(drectives)

    在大多数情况下,你都可以操作数据来修改视图,或者反之.但是还是避免不了偶尔要操作原生 DOM,这时候,你就能用到自定义指令. 举个例子,你想让页面的文本框自动聚焦,在没有学习自定义指令的时候,我们可能 ...

  8. AngularJS学习笔记(五)自定义指令(1)

    先来说说自定义指令 ng通过内置指令的方式实现了对html的增强,同时也赋予了我们自定义指令的功能,让我们根据实际需求进行指令的定制.自定义指令涉及到模板(template).作用域(scope).数 ...

  9. Vue2.0 【第二季】第1节 Vue.directive自定义指令

    目录 Vue2.0 [第二季]第1节 Vue.directive自定义指令 一.什么是全局API? 二. Vue.directive自定义指令 三.自定义指令中传递的三个参数 四.自定义指令的生命周期 ...

随机推荐

  1. Java容器类源码分析之Iterator与ListIterator迭代器(基于JDK8)

    一.基本概念 迭代器是一个对象,也是一种设计模式,Java有两个用来实实现迭代器的接口,分别是Iterator接口和继承自Iterator的ListIterator接口.实现迭代器接口的类的对象有遍历 ...

  2. Java学习笔记之——变量与数据类型、运算符

    一.变量 1.变量:变化的值 变量在代码运行期间,开辟了一块空间 .这块空间是有地址的,给这块取了个名字, 这个名字就叫做变量名,这块空间放的东西叫做变量值 2.变量的初始化: (1)先声明再赋值: ...

  3. 【pygame游戏编程】第四篇-----打字测速游戏

    下面我们一起用pygame编写一个打字测速游戏 这是一个很实用的有趣的小游戏: 开始之前先来学习几个小函数: 1. ord(ch) python内置函数,传入一个字符,返回字符的ascii码 2.ch ...

  4. git命令详解( 四 )

    此篇为git命令详解的第四篇,话不多说,我们直接上知识点好吧 git Push 偏离的工作 gitPush: 此命令负责将你的变更上传到指定的远程仓库,并在远程仓库上合并你的新提交记录.一旦 git ...

  5. ionic 开发解决ios上qq客服链接不跳转或者跳转到appstore

    不能跳转的情况需要 在ionic项目根目录下,打开config.xml文件,在<access origin="*" />后添加<allow-navigation ...

  6. web全栈架构师[笔记] — 03 html5新特性

    HTML5新特性 一.geolocation PC端 精度比较低 通过IP库定位 移动端 通过GPS window.navigator.geolocation 单次 getCurrentPositio ...

  7. FI / CO 配置步骤清单

    一.FI配置 01. 创建公司代码:企业结构-定义-财务会计-编辑/复制/删除/检查公司代码.编辑公司OX02 02. 创建会计科目表 OB13 03. 定义会计年度变式 OB29 04. 创建信贷控 ...

  8. 对比学IT---路由器和linux流量统计的差别

    1. 路由器使用MQC来统计端口入出方向,特定特征的数据流. 显示policy 的统计信息 配置policy: #traffic classifier vlan5traffic operator an ...

  9. MVC与单元测试实践之健身网站(四)-动作管理

    网站后台负责进行动作的管理,包括动作名称.介绍.训练要点.配图等内容,以便前台能够使用这些内容.在上一篇< Fit项目图片上传和云存储的调通>中已经准备好了这里涉及到的主要技术难点,现在就 ...

  10. Pycharm2017常用快捷键

    Pycharm 的快捷键可以在[文件]-[设置]中自定义(见上图). 下方是根据网上资料整理的官方默认快捷键设置. 常用快捷键 Ctrl + / 行注释/取消行注释 Tab / Shift + Tab ...