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-cssv-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 &#39;ejs&#39;的解决办法  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整体框架之基础布局组件