vue.js中指令Directives详解
发布时间 - 2026-01-11 00:15:31 点击率:次想必喜欢前端开发的小伙伴们都或多或少接触过MVVM这个概念,说起MVVM,第一时间想到的便是angularjs,knockoutjs等已经被广泛运用的MVVM框架,之前我也没有在这方面有很多了解,最近在做项目的过程中接触了Vue.js,这是一个小巧精致,性能优异的MVVM框架,可以说对初学者是比较容易入门的,该框架的英文文档写得很好,但是中文版访问还不太稳定,翻译也有待改进,所以自己一遍学习,一遍记录自己的思考,与各位共享学习的经验。
第一篇主要是想谈谈vue.js中的Directives即指令,在vue.js中指令就是一个通知库进行某些具体的dom操作的口令,在html中表现为如下形式:
<element prefix-directiveId="[argument:] expression [| filters...]"> </element>
Directives分为1.Reactive Directives、2.Literal Directives、3.Empty Directives,下面结合具体的api阐述他们的作用:
1.Reactive Directives(响应式指令)
Reactive Directives可以绑定在Vue实例或者在Vue实例上下文中求值的表达式上,当绑定的对象发生改变时,指令中的update()会在下一个系统单位时间发生异步响应,我们来看看具体的用法:
v-text:更新元素的textContent,事实上在html中{{mustache}}形式的插入值也会被编译为针对一个textNode的v-text指令。
v-html:更新元素的innerHTML,由于可能插入恶意代码,使用时要注意保证来源安全。
v-show:根据绑定值的true或false来决定所在元素在网页中正常显示还是显示为空。
v-class:这个指令有一个可选参数,无参数时将绑定值(一般为class名)添加到所在元素的classlist当中,并且一旦检测绑定值有改动,便随之改变classlist里对应的class;提供参数时参数的true或false将决定绑定值(class)是否被添加到所在元素的classlist中,示例如下:
<span v-class=" red : hasError, bold : isImportant, hidden : isHidden "></span>
v-attr:更新所在元素的某些属性(由参数表示)。
<canvas v-attr="width:w, height:h"></canvas>
v-style:更新所在元素的样式,会智能添加浏览器供应商前缀,方便我们书写样式。这个指令有一个可选参数,无参数时,若绑定值为String则将绑定值设置为元素的style.cssText,若绑定值为Object则将Object中的样式键值对放入元素的style object当中;
<div v-style="myStyles"></div>
// myStyles can either be a String:
"color:red; font-weight:bold;"
// or an Object:
{
color: 'red',
// both camelCase and dash-case works
fontWeight: 'bold',
'font-size': '2em'
}
提供参数时,参数指明了css属性的对应值:
<div v-style=" top: top + 'px', left: left + 'px', background-color: 'rgb(0,0,' + bg + ')' "></div>
v-on:为元素添加并更新事件监听器,参数可以是一个处理函数或者一个函数语句。
<div id="demo"> <a v-on="click: onClick">Trigger a handler</a> <a v-on="click: n++">Trigger an expression</a> </div>
我们可以为处理函数提供参数,其中this指的是当前的ViewModel,如下例中通过传入this参数改变元素的text值:
<ul id="list">
<li v-repeat="items" v-on="click: toggle(this)">{{text}}</li>
</ul>
new Vue({
el: '#list',
data: {
items: [
{ text: 'one', done: true },
{ text: 'two', done: false }
]
},
methods: {
toggle: function (item) {
item.done = !item.done
}
}
})
我们还可以传入$event表示触发处理函数的DOM事件,如下例传入$event阻止事件冒泡:
<button v-on="click: submit('hello!', $event)">Submit</button>
/* ... */
{
methods: {
submit: function (msg, e) {
e.stopPropagation()
}
}
}
/* ... */
在监听键盘事件时由于要判断按键值,可以结合filter写成如下两种形式:
<!-- only call vm.submit() when the keyCode is 13 --> <input v-on="keyup:submit | key 13"> <!-- same as above --> <input v-on="keyup:submit | key enter">
当ViewModel销毁时,v-on绑定的事件会自动消除,我们不必亲自去清理这些绑定事件,这也防止了内存的泄露。
v-model:为表单元素创建一个双向绑定,详细介绍请看这里
v-if:根据绑定值的true或false来插入或移除元素,如例子中我们将根据test的正确与否决定两个<p>元素是否插入<template>当中
<template v-if="test"> <p>hello</p> <p>world</p> </template>
v-repeat:为绑定数组或对象中的每一个item创建一个子ViewModel,或者为绑定的数字值创建对应数量的子ViewModel。并根据绑定值的改变随时更新。没有提供参数时子ViewModel会直接使用绑定数组中的分配单元作为它的$data,如果值不是一个对象,则会创建一个数据包装对象,而值会被设置在别名为$value的 key 上。
<ul>
<li v-repeat="users">
{{name}} {{email}}
</li>
</ul>
如果提供了参数,我们将创建一个数据包装对象,将参数作为对象的key,从而访问对象模板中的属性:
<ul>
<li v-repeat="user : users">
{{user.name}} {{user.email}}
</li>
</ul>
v-with:这个指令只能结合接下来讲到的v-component指令使用,作用是让子ViewModel可以继承父ViewModel的数据,我们可以传入父ViewModel的属性对象或单个属性,在子ViewModel中访问:
// parent data looks like this
{
user: {
name: 'Foo Bar',
email: 'foo@bar.com'
}
}
继承对象:
<my-component v-with="user">
<!-- you can access properties without `user.` -->
{{name}} {{email}}
</my-component>
继承单个属性:
<my-component v-with="myName: user.name, myEmail: user.email">
<!-- you can access properties with the new keys -->
{{myName}} {{myEmail}}
</my-component>
v-events:这个指令也只能结合接下来讲到的v-component指令使用,它使得父ViewModel能够监听子ViewModel上的事件,我们要注意区分v-on与v-events,v-events监听的是通过vm.$emit()创建的 Vue 组件系统事件,而不是 DOM 事件。我们举例说明:
<!-- inside parent template --> <div v-component="child" v-events="change: onChildChange"></div>
当子ViewModel调用this.$emit('change', …)时会触发父ViewModel的onChildChange()方法,并且把emit函数中附加的参数传给onChildChange()方法。
2.Literal Directives(字面指令)
字面指令并没有绑定到某一个对象上,字面指令是把它们的参数作为纯字符串传给bind()函数中执行一次,字面指令可以接受{{mustache}}表达式,但是该表达式只会在编译阶段执行一次,不会绑定数据的改变:
下面看一看具体的api:
v-component:之前提到过,这是使用我们提前声明并注册好的组件构造器将当前元素编译为子ViewModel,从而实现数据继承,之后的文章会详细介绍组件系统。
v-ref:在父ViewModel中创建子ViewModel的引用,方便父ViewModel中的$对象访问子组件:
<div id="parent"> <div v-component="user-profile" v-ref="profile"></div> </div>
var parent = new Vue({ el: '#parent' })
// 访问子组件
var child = parent.$.profile
这个指令只能与v-component和v-repeat一起使用,与v-repeat一起使用时,其value是与绑定数据数组对应的子组件数组。
v-el:为当前dom元素创建一个引用,供其自身vue实例使用,例如<div v-el="hi">可以使得vm.$$.hi访问到该dom元素
v-partial:将当前dom元素中的innerHTML替换为事先注册的partial,有两种写法,{{ mustache}}可以让dom元素随数据改变而更新:
<!-- content will change based on vm.partialId -->
<div v-partial="{{partialId}}"></div>
另一种写法则没有数据跟随更新的效果:
<div>{{> my-partial}}</div>
v-transition:为当前dom元素在指定参数值作用时添加动画效果,后续文章会详细介绍
3.Empty Directives(字面指令)
v-pre:这个指令是通知编译器跳过当前dom元素和其所有子元素,这是为了在我们编程过程中对无需编译的元素节省编译时间
v-cloak:在当前元素编译完成之前改指令都会存在,我们一般使用这个指令来在元素编译未完成时隐藏原始的 {{ Mustache }} 模板,可以在css中这样写:
[v-cloak] { display: none }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# vue.js
# Directives
# 指令
# vue 自定义指令directives及其常用钩子函数说明
# vue filters和directives访问this的问题详解
# vue通过指令(directives)实现点击空白处收起下拉框
# vue.js自定义组件directives的实例代码
# 详解vue + vuex + directives实现权限按钮的思路
# vue3的自定义指令directives实现
# 绑定
# 定值
# 创建一个
# 详细介绍
# 这是
# 一遍
# 我们可以
# 可选
# 讲到
# 值为
# 则将
# 有一个
# 自己的
# 的是
# 译为
# 是一个
# 我也
# 他们的
# 很好
# 也会
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
香港服务器租用每月最低只需15元?
Laravel如何处理异常和错误?(Handler示例)
canvas 画布在主流浏览器中的尺寸限制详细介绍
详解Android图表 MPAndroidChart折线图
非常酷的网站设计制作软件,酷培ai教育官方网站?
高防服务器租用指南:配置选择与快速部署攻略
品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?
JavaScript数据类型有哪些_如何准确判断一个变量的类型
Laravel Artisan命令怎么自定义_创建自己的Laravel命令行工具完全指南
,网页ppt怎么弄成自己的ppt?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted
如何在万网开始建站?分步指南解析
Laravel怎么上传文件_Laravel图片上传及存储配置
如何在宝塔面板中创建新站点?
HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】
关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)
Laravel API资源(Resource)怎么用_格式化Laravel API响应的最佳实践
微信小程序 require机制详解及实例代码
如何在阿里云ECS服务器部署织梦CMS网站?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
Android 常见的图片加载框架详细介绍
如何在Windows环境下新建FTP站点并设置权限?
简单实现Android文件上传
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析
Laravel如何实现密码重置功能_Laravel密码找回与重置流程
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
如何在局域网内绑定自建网站域名?
如何快速查询网址的建站时间与历史轨迹?
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
如何挑选高效建站主机与优质域名?
企业网站制作这些问题要关注
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
Laravel如何生成API文档?(Swagger/OpenAPI教程)
Laravel队列任务超时怎么办_Laravel Queue Timeout设置详解
Laravel模型事件有哪些_Laravel Model Event生命周期详解
Laravel如何实现本地化和多语言支持?(i18n教程)
Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制
Win11怎么更改系统语言为中文_Windows11安装语言包并设为显示语言
如何在服务器上配置二级域名建站?
Laravel如何使用Gate和Policy进行权限控制_Laravel权限判定与策略规则配置
如何有效防御Web建站篡改攻击?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
在Oracle关闭情况下如何修改spfile的参数
laravel怎么配置和使用PHP-FPM来优化性能_laravel PHP-FPM配置与性能优化方法
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门

