当前位置: 首页 > article >正文

vue3 自定义指令 directive

1、官方说明:https://cn.vuejs.org/guide/reusability/custom-directives

除了 Vue 内置的一系列指令 (比如 v-model 或 v-show) 之外,Vue 还允许你注册自定义的指令 (Custom Directives)。

我们已经介绍了两种在 Vue 中重用代码的方式:组件和组合式函数。组件是主要的构建模块,而组合式函数则侧重于有状态的逻辑。另一方面,自定义指令主要是为了重用涉及普通元素的底层 DOM 访问的逻辑。

2、案例说明:

新建文件vNameOfDirectiveTest.vue

代码:

<script setup>
const vMyDirective = {
  beforeMount: (el) => {
    // 在元素上做些操作
    console.log(el);
    el.style.color = 'red'
    el.style.backgroundColor = 'yellow'
  }
}
</script>
<template>
  <h1 v-my-directive>This is a Heading</h1>
  <div v-color="'red'">This text will be red.</div>
  <input v-focus value="This is a input"></input>
</template>

说明

vMyDirective:局部指令。

v-color,v-focus:全局指令。

const app = createApp(App);
// 注册自定义指令
const color = {
  mounted(el, binding) {
    el.style.color = binding.value;
  },
  // 如果需要在更新时也更新颜色,可以添加一个 `updated` 钩子
  // updated(el, binding) {
  //   el.style.color = binding.value;
  // }
};

app.directive("focus", {
  mounted(el) {
    el.focus();
  },
});

// 全局注册自定义指令
app.directive('color', color);

3、注意:

<div v-color="'red'">This text will be red.</div>

这里的v-color="'red'",red一定要有二个单引号引起来,否则不生效,实测生效。


http://www.kler.cn/a/302046.html

相关文章:

  • 【Python进阶】Python中的数据库交互:使用SQLite进行本地数据存储
  • 【Conda】Windows下conda的安装并在终端运行
  • 初识Linux · 共享内存
  • 『VUE』27. 透传属性与inheritAttrs(详细图文注释)
  • 【Linux】Linux 权限的理解
  • LeetCode面试经典150题C++实现,更新中
  • CSS-3
  • 如何让大模型更好地进行场景落地?
  • OpenSSL工具验证RSA证书
  • C# 批量更改文件后缀名称
  • 软件测试中常用模型分析
  • 【编程底层思考】性能监控和优化:JVM参数调优,诊断工具的使用等。JVM 调优和线上问题排查实战经验总结
  • 【C语言从不挂科到高绩点】17-C语言中的宏定义
  • 云服务器 卸载mysql5并安装mysql8(图文)
  • docker-compose 部署 flink
  • 笔试强训day10
  • C#基础(10)变长参数和参数默认值
  • 数据结构之数组矩阵存储
  • 树莓派安装 OpenCV 教程
  • 110个oracle常用函数总结
  • uniapp中基于vue3实现输入验证码功能
  • Android 地图搜索商家,检索关键字(高德地图,百度地图),地址搜索(1)
  • windows 显示进程地址空间
  • win11下面的virtualenv的使用(没写完)
  • Excel文档的读取(3)
  • 93、k8s之hpa+helm