自定义指令:让 Vue 开发更有趣(中)

news2025/1/12 1:41:32

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 四、编写自定义指令
    • 使用 Vue 的`directive`选项注册指令
    • 定义指令的生命周期钩子函数
    • 使用模板语法在模板中使用自定义指令
  • 五、使用示例
    • 实现一个简单的计数器指令
    • 创建一个切换元素可见性的指令

四、编写自定义指令

使用 Vue 的directive选项注册指令

在 Vue 中,可以使用 directive 选项来注册自定义指令。下面是一个使用 directive 选项注册自定义指令的示例:

Vue.directive('my-directive', {
 // 指令的选项
 bind: function (el, binding, vnode) {
   // 指令绑定时的操作
 },
 inserted: function (el, binding, vnode) {
   // 指令插入时的操作
 },
 update: function (el, binding, vnode, oldVnode) {
   // 指令更新时的操作
 },
 componentUpdated: function (el, binding, vnode, oldVnode) {
   // 指令组件更新时的操作
 },
 unbind: function (el, binding, vnode) {
   // 指令解绑时的操作
 }
});

在这个示例中,我们注册了一个名为 my-directive 的自定义指令,并定义了以下选项:

  • bind:指令绑定时的操作,例如设置指令的属性值。
  • inserted:指令插入时的操作,例如设置指令的 DOM 节点。
  • update:指令更新时的操作,例如更新指令的属性值。
  • componentUpdated:指令组件更新时的操作,例如更新指令的组件状态。
  • unbind:指令解绑时的操作,例如清理指令的 DOM 节点。

注册自定义指令后,可以在 Vue 模板中使用 v-my-directive 指令,例如:

<template>
 <div>
   <p v-my-directive="message">Hello, world!</p>
 </div>
</template>

<script>
export default {
 data() {
   return {
     message: 'Hello, world!'
   };
 }
};
</script>

在这个示例中,我们使用了 v-my-directive 指令,将 <p> 标签的文本内容设置为 message 数据属性的值,即 Hello, world!

总的来说,使用 directive 选项可以方便地注册自定义指令,并定义指令的生命周期钩子函数,实现各种指令效果。

定义指令的生命周期钩子函数

在 Vue 中,自定义指令的生命周期钩子函数包括以下几个:

  1. bind:指令被绑定到元素时调用,这是指令的初始化阶段,可以在这个函数中进行一些初始化操作,例如设置指令的属性值、操作 DOM 节点等。
  2. inserted:指令被插入到 DOM 中时调用,通常用于设置事件监听器、计算属性等。
  3. update:指令的属性值发生更新时调用,可以在这个函数中进行更新操作,例如更新 DOM 节点的内容、更新事件监听器等。
  4. componentUpdated:指令的组件状态发生更新时调用,例如指令的组件属性发生更新时,可以在这个函数中进行更新操作。
  5. unbind:指令与元素解绑时调用,可以在这个函数中进行清理操作,例如移除事件监听器、清理 DOM 节点等。

下面是一个定义指令生命周期钩子函数的示例:

Vue.directive('my-directive', {
 // 指令的选项
 bind: function (el, binding, vnode) {
   // 指令绑定时的操作
   el.style.backgroundColor = binding.value;
 },
 inserted: function (el, binding, vnode) {
   // 指令插入时的操作
   el.onclick = function () {
     alert('Directive clicked!');
   };
 },
 update: function (el, binding, vnode, oldVnode) {
   // 指令更新时的操作
   el.style.backgroundColor = binding.value;
 },
 componentUpdated: function (el, binding, vnode, oldVnode) {
   // 指令组件更新时的操作
 },
 unbind: function (el, binding, vnode) {
   // 指令解绑时的操作
   el.onclick = null;
 }
});

在这个示例中,我们定义了一个名为 my-directive 的自定义指令,并定义了 bindinsertedupdatecomponentUpdatedunbind 生命周期钩子函数。

  • bind 函数:指令绑定时调用,设置指令的属性值,将元素的背景颜色设置为指令的值。
  • inserted 函数:指令插入时调用,设置事件监听器,当点击元素时弹出警告框。
  • update 函数:指令更新时调用,将元素的背景颜色设置为指令的值。
  • componentUpdated 函数:指令组件更新时调用,不做任何操作。
  • unbind 函数:指令解绑时调用,移除事件监听器,避免内存泄漏。

总的来说,定义指令的生命周期钩子函数可以方便地实现各种指令效果,例如设置属性值、操作 DOM 节点、设置事件监听器等。

使用模板语法在模板中使用自定义指令

在 Vue 中,可以使用模板语法在模板中使用自定义指令。下面是一个使用模板语法在模板中使用自定义指令的示例:

<template>
<div>
  <p v-my-directive="message">Hello, world!</p>
  <button v-my-directive="'red'">Red button</button>
</div>
</template>

<script>
export default {
data() {
  return {
    message: 'Hello, world!',
    color: 'blue'
  };
},
directives: {
  'my-directive': {
    bind: function (el, binding, vnode) {
      el.style.color = binding.value;
    },
    inserted: function (el, binding, vnode) {
      el.onclick = function () {
        alert('Directive clicked!');
      };
    },
    update: function (el, binding, vnode, oldVnode) {
      el.style.color = binding.value;
    }
  }
}
};
</script>

在这个示例中,我们定义了一个名为 my-directive 的自定义指令,并在 directives 选项中注册了该指令。然后,我们在模板中使用 v-my-directive 指令,将 <p> 标签的文本内容设置为 message 数据属性的值,即 Hello, world!。同时,我们还使用 v-my-directive 指令为 <button> 标签设置了一个自定义的颜色属性,将其颜色设置为 red

总的来说,使用模板语法可以在 Vue 中方便地使用自定义指令,实现各种指令效果。

五、使用示例

实现一个简单的计数器指令

下面是一个简单的计数器指令的实现:

首先,在 Vue 中定义一个名为 counter-directive 的自定义指令:

Vue.directive('counter', {
 // 初始化时调用
 bind: function (el, binding, vnode) {
   // 获取绑定值
   const count = binding.value;
   // 初始化计数器
   el.count = count;
   // 更新计数器
   el.oninput = function () {
     // 获取输入的值
     const value = this.value;
     // 如果输入的值不是数字,则清除输入框的值
     if (!isNaN(value)) {
       // 更新计数器的值
       this.count = value;
     } else {
       this.value = el.count;
     }
   };
 }
});

接下来,在 Vue 模板中使用 counter 指令:

<template>
 <div>
   <input type="text" v-counter="10">
 </div>
</template>

在这个示例中,我们定义了一个名为 counter 的自定义指令,用于实现计数器的功能。当 counter 指令被绑定到元素时,它会获取绑定值,并初始化一个名为 count 的数据属性,用于存储计数值。同时,它还设置了一个名为 oninput 的监听器,用于监听输入框的输入事件。当输入框的值发生变化时,oninput 监听器会被触发,它会获取输入的值,并将其转换为数字类型。如果输入的值不是数字,则不会更新计数器的值,而是将输入框的值恢复为当前计数器的值。如果输入的值是数字,则会更新计数器的值。

总的来说,这个简单的计数器指令可以实现基本的计数功能,可以根据需要进行扩展和自定义。

创建一个切换元素可见性的指令

下面是一个创建一个切换元素可见性指令的实现:

首先,在 Vue 中定义一个名为 toggle-visibility 的自定义指令:

Vue.directive('toggle-visibility', {
 // 初始化时调用
 bind: function (el, binding, vnode) {
   // 获取绑定值
   const visibility = binding.value;
   // 设置元素的可见性
   el.style.display = visibility ? 'block' : 'none';
 }
});

接下来,在 Vue 模板中使用 toggle-visibility 指令:

<template>
<div>
  <button v-toggle-visibility="true">显示</button>
  <button v-toggle-visibility="false">隐藏</button>
</div>
</template>

在这个示例中,我们定义了一个名为 toggle-visibility 的自定义指令,用于切换元素的可见性。当 toggle-visibility 指令被绑定到元素时,它会获取绑定值,并设置元素的 display 属性为 blocknone,从而实现元素的可见性切换。

总的来说,这个简单的切换元素可见性指令可以实现基本的可见性切换功能,可以根据需要进行扩展和自定义。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1351483.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一年中ChatGPT使用情况

介绍 本人是独立开源软件开发者&#xff0c;参与很多项目建设&#xff0c;谈下日常使用情况。 我用了一年多&#xff0c;现在已经离不开&#xff0c;我如指挥家&#xff0c;它是我最忠诚的乐手。 编码 GitHub Copilot&#xff1a;GitHub Copilot是GitHub和OpenAI合作开发的一…

unity C# 中通俗易懂LINQ使用案例

文章目录 1. 从数组或列表中查询元素**&#xff1a;2. **排序与分组**&#xff1a;3. **连接多个数据源**&#xff1a;4. **聚合操作**&#xff1a;5. **分页查询**&#xff1a;6. **多条件查询**&#xff1a;7. **转换和投影&#xff08;Select&#xff09;**&#xff1a;8. *…

[C#]使用onnxruntime部署Detic检测2万1千种类别的物体

【源码地址】 github地址&#xff1a;https://github.com/facebookresearch/Detic/tree/main 【算法介绍】 Detic论文&#xff1a;https://arxiv.org/abs/2201.02605v3 项目源码&#xff1a;https://github.com/facebookresearch/Detic 在Detic论文中&#xff0c;Detic提到…

SpringBoot整合Elasticsearch报错

本文来记录一下SpringBoot整合Elasticsearch报错 文章目录 报错如下报错原因es7.15.2版本下载 报错如下 报错如下 2024-01-02 15:09:10.349 ERROR 134936 --- [nio-8088-exec-6] o.a.c.c.C.[.[.[/]. [dispatcherServlet] : Servlet.service() for servlet [dispatcherServle…

华清远见作业第十九天——IO(第二天)

思维导图&#xff1a; 使用fread、fwrite完成两个文件的拷贝 代码&#xff1a; #include<stdio.h> #include<string.h> #include<stdlib.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> int main(int argc, const…

kubeadm来快速搭建一个K8S集群

二进制搭建适合大集群&#xff0c;50台以下的主机 kubeadm更适合中下企业的业务集群 我们采用了二进制包搭建出的k8s集群&#xff0c;本次我们采用更为简单的kubeadm的方式来搭建k8s集群。 二进制的搭建更适合50台主机以上的大集群&#xff0c;kubeadm更适合中小型企业的集群…

如何保障集团下达的政策要求有效落地

随着新一轮国企改革的推进&#xff0c;很多国有企业建立了集团化的管控体系。通过集团化经营管理的模式&#xff0c;帮助国有企业凝聚更强的竞争力&#xff0c;集团企业通过资源整合、反向投资、控股、参股等手法创造业务板块之间的协同、互补效应&#xff0c;从而实现战略联动…

Redis(二)数据类型

文章目录 官网备注十大数据类型StringListHashSetZSetBitmapHyperLogLog&#xff1a;GEOStreamBitfield 官网 英文&#xff1a;https://redis.io/commands/ 中文&#xff1a;http://www.redis.cn/commands.html 备注 命令不区分大小写&#xff0c;key区分大小写帮助命令help…

vue +elementui 项目登录通过不同账号切换侧边栏菜单的颜色

前景提要&#xff1a;要求不同权限账号登录侧边栏颜色不一样。分为 theme&#xff1a;1代表默认样式&#xff0c;theme:2代表深色主题样式。 1.首先定义一个主题文件 theme.js&#xff0c;定义两个主题样式 // 主要是切换菜单栏和菜单头部主题的设计&#xff0c;整体主题样式切…

第4课 FFmpeg读取本地mp4文件并显示

在上节课&#xff0c;我们使用FFmpeg实现了一个最简单的rtmp播放器&#xff0c;它看起来工作正常。这节课&#xff0c;我们尝试让它来播放本地的mp4文件试试。 1.压缩备份上节课工程文件夹为demo3.rar&#xff0c;并修改工程文件夹demo3为demo4&#xff0c;重要的事情再说一遍…

BERT(从理论到实践): Bidirectional Encoder Representations from Transformers【1】

预训练模型:A pre-trained model is a saved network that was previously trained on a large dataset, typically on a large-scale image-classification task. You either use the pretrained model as is or use transfer learning to customize this model to a given t…

认识SpringBoot项目中的Starter

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 循序渐进学SpringBoot ✨特色专栏&…

【MySQL四大引擎,数据库管理,数据表管理,数据库账号管理】

一. MySQL四大引擎 查看存储引擎 SHOW ENGINES support 字段说明 defaulti的为默认的引擎 为YES表示可以使用 为NO表示不能使用 四大引擎 InnoDB InnoDB表类型可以看作是对MyISAM的进一步更新产品&#xff0c;它提供了事务、行级锁机制和外键约束的功能&#xff0c;也是目前…

初中数学:一元二次方程和一元二次函数的相关总结

一、一元二次方程 1、定义 只含有一个未知数&#xff0c;且未知数的最高次数是2的整式方程。 表达式&#xff1a;axbxc0 2、常用解法 1、直接开平方法 2、配方法 3、公式法。(常用) x[-b√(b-4ac)]/2a 4、因式分解法&#xff08;十字相乘法&#xff09;(常用) 将方程通过…

This is probably not a problem with npm.

项目场景&#xff1a; 新创建的vue3项目&#xff0c;根据elementplus官网安装步骤进行按需导入安装&#xff0c;运行项目报错 This is probably not a problem with npm.There is likely additional logging output above. 原因分析&#xff1a; 是elementplus安装版本和自动…

kbdnecat.DLL文件缺失,软件或游戏无法启动运营,快速修复方法

“kbdnecat.DLL文件是什么&#xff1f;为什么一起动游戏或软件&#xff0c;Windows就报错“kbdnecat.DLL文件缺失&#xff0c;软件无法启动””&#xff0c;应该怎么修复呢&#xff1f; 首先&#xff0c;先来了解“kbdnecat.DLL文件”是什么&#xff1f; kbdnecat.DLL是一个动…

CSS渲染性能优化

✨ 专栏介绍 HTML/CSS专栏合集是一个涵盖HTML和CSS两个方面的栏目。HTML是一种标记语言&#xff0c;用于创建网页的结构和内容&#xff0c;而CSS是一种样式表语言&#xff0c;用于控制网页的外观和布局。 在HTML/CSS专栏合集中&#xff0c;我们将深入探讨HTML和CSS的基础知识…

Python内置库os和sys的常用方法汇总

更多Python学习内容&#xff1a;ipengtao.com Python是一门强大的编程语言&#xff0c;具有丰富的标准库&#xff0c;其中包括os和sys两个常用模块。os模块用于与操作系统交互&#xff0c;提供了许多文件和目录操作的方法&#xff0c;而sys模块用于与Python解释器进行交互&…

How to understand the Trusted Intelligent Computing Service in Huawei Cloud

How to understand the Trusted Intelligent Computing Service in Huawei Cloud 概述什么是TICS产品架构TICS规格说明产品优势产品功能应用场景政企信用联合风控政府数据融合共治金融联合营销使能数据交易 快速入门TICS快速入门TICS使用流程简介入门实践 概述 什么是TICS 可信…

07. HTTP接口请求重试怎么处理?

目录 1、前言 2、实现方式 2.1、循环重试 2.2、递归重试 2.3、Spring Retry 2.4、Resilience4j 2.5、http请求网络工具内置重试方式 2.6、自定义重试工具 2.7、并发框架异步重试 2.8、消息队列 3、小结 1、前言 HTTP接口请求重试是指在请求失败时&#xff0c;再次发…