vue.js内部自定义指令与全局自定义指令的实现详解(利用directive)
发布时间 - 2026-01-11 02:16:41 点击率:次前言

大家都知道在Vue中,我们平时数据驱动视图时候,内部自带的指令有时候解决不了一些需求,这时候,Vue给我们一个很好用的东东来实现自定义指令,这就是directive。下面话不多说了,来一起看看详细的介绍:
directive
这个单词是我们写自定义指令的关键字哦
自定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表现状态
- bind: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作。
- inserted: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。
- update: 被绑定元素所在的模板更新时调用,而不论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新(详细的钩子函数参数见下)。
- componentUpdated: 被绑定元素所在模板完成一次更新周期时调用。
- unbind: 只调用一次, 指令与元素解绑时调用。
下面我们开始上代码,让我们更好的理解自定义指令怎么做
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
</head>
<body>
<div id="app">
<div class="ab" v-css="{'color':'red','font-size':'30px'}">
hello
</div>
<input type="text" v-focus>
</div>
</body>
</html>
在html中,我们看到了两个指令v-css和v-focus
我们自定义指令时候,一定前面要带上v-
Vue.directive("css",{
//钩子函数 ,el就是当前元素
inserted(el,binding){
//el绑定的元素本身
//binding就是css指令里面的的对象元素
let styleobj=binding.value,arr=[];
for(let key in styleobj){
arr.push(key+":"+styleobj[key])
}
arr=arr.join(";");
el.style.cssText=arr;
},
bind(el,binding) {
//指令绑定在元素上时候执行,只执行一次
}
});
new Vue({
el:'#app',
data:{
show:true
},
directives:{
focus:{
inserted(el,binding){
//el绑定的元素本身
//binding就是css指令里面的的对象元素
el.focus();
}
}
}
});
在js里面我们可以看到
Vue.directive("css",{})
我们在 new Vue外部定义了这样一段代码,这就是我们全局自定义指令的模板方式
- css是自定义指令的名字
- {}里面我们写上钩子函数就可以
我们所有的钩子函数里面,基本都会有2个参数el,binding
- el: 指令所绑定的元素,可以用来直接操作 DOM 。
- binding 绑定元素本身的一个对象
从上面我们可以看到,binding里面保留绑定指令的name和value,这些很重要
局部自定义指令
directives:{
name:{
}
}
区别在于,我们写在new Vue里面,里面api操作和上面的全局自定义指令一样
下面我们开始看代码运行结果
我们可以看到样式引用上去了
文本框也获取了焦点
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
# vue
# 自定义全局指令
# vue.js
# 自定义指令
# directive
# Vue.js directive自定义指令详解
# Vue.js源码分析之自定义指令详解
# Vue.js自定义指令学习使用详解
# 浅谈Vue.js中如何实现自定义下拉菜单指令
# 详解Vue.js组件可复用性的混合(mixin)方式和自定义指令
# Vue.js自定义指令的基本使用详情
# 自定义
# 绑定
# 可以看到
# 这就是
# 东来
# 这时候
# 定值
# 几个
# 会有
# 大家都
# 让我们
# 说了
# 不多
# 给我们
# 很重要
# 怎么做
# 这篇文章
# 你一定
# 自带
# 谢谢大家
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
javascript中的try catch异常捕获机制用法分析
如何快速搭建二级域名独立网站?
Laravel如何为API编写文档_Laravel API文档生成与维护方法
html5的keygen标签为什么废弃_替代方案说明【解答】
昵图网官网入口 昵图网素材平台官方入口
Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】
Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
香港服务器如何优化才能显著提升网站加载速度?
Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程
如何破解联通资金短缺导致的基站建设难题?
node.js报错:Cannot find module 'ejs'的解决办法
Laravel项目怎么部署到Linux_Laravel Nginx配置详解
Android 常见的图片加载框架详细介绍
Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程
无锡营销型网站制作公司,无锡网选车牌流程?
如何在IIS中配置站点IP、端口及主机头?
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
如何在云主机快速搭建网站站点?
Laravel如何集成微信支付SDK_Laravel使用yansongda-pay实现扫码支付【实战】
如何撰写建站申请书?关键要点有哪些?
大同网页,大同瑞慈医院官网?
canvas 画布在主流浏览器中的尺寸限制详细介绍
Java垃圾回收器的方法和原理总结
Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】
laravel怎么配置Redis作为缓存驱动_laravel Redis缓存配置教程
如何正确下载安装西数主机建站助手?
Mybatis 中的insertOrUpdate操作
如何在宝塔面板中修改默认建站目录?
香港服务器部署网站为何提示未备案?
Laravel如何使用Vite进行前端资源打包?(配置示例)
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
javascript如何操作浏览器历史记录_怎样实现无刷新导航
Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解
浅述节点的创建及常见功能的实现
Laravel如何正确地在控制器和模型之间分配逻辑_Laravel代码职责分离与架构建议
Android中Textview和图片同行显示(文字超出用省略号,图片自动靠右边)
如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环
php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】
开心动漫网站制作软件下载,十分开心动画为何停播?
如何用狗爹虚拟主机快速搭建网站?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
如何选择PHP开源工具快速搭建网站?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
个人网站制作流程图片大全,个人网站如何注销?
微信小程序 配置文件详细介绍
Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)
三星、SK海力士获美批准:可向中国出口芯片制造设备
BootStrap整体框架之基础布局组件

