iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >vue自定义封装指令及实际使用的方法
  • 381
分享到

vue自定义封装指令及实际使用的方法

2023-06-29 00:06:01 381人浏览 薄情痞子
摘要

本篇内容主要讲解“Vue自定义封装指令及实际使用的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue自定义封装指令及实际使用的方法”吧!前言vue默认内置了v-model、v-if、v-s

本篇内容主要讲解“Vue自定义封装指令及实际使用的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue自定义封装指令及实际使用的方法”吧!

    前言

    vue默认内置了v-model、v-if、v-show、v-html、v-text等指令,但是这些往往不足以满足我们实际项目开发中的场景,比如权限控制按钮、路由菜单,复制文字等功能,就需要我们自己自定义一些满足我们项目需求的指令了,那怎么封装自定义指令,并使用呢?我们先从封装指令的基础说起。

    封装指令基础

    钩子函数

    • bind:只调用一次,指令第一次绑定到元素时调用。可以进行一次性初始化设置。

    • inserted:被绑定元素插入父节点时调用(仅保证父节点存在,但不一定已经被插入文档中)。

    • update:所在组件的Vnode更新时调用,也可能发生在其子VNode更新之前。

    • componentUpdated:指令所在组件的VNode及其子VNode全部更新后调用。

    • unbind:只调用一次,指令与元素解绑时调用。

    钩子函数参数

    钩子函数参数包含了el、binding、vnode、oldVnode。

    • el:指令所绑定的元素,可以用来直接操作DOM。

    • binding:一个对象,包含以下属性

      • name:指令名。不包括v-前缀(如:v-copy的name为copy)。

      • value:指令的绑定值(如:v-copy='1 + 1'中,value值为2)。

      • oldValue:指令绑定的前一个值,仅在update和componentUpdated钩子函数中可用,无论值是否改变都可用。

      • expression:字符串形式的指令表达式(如:v-copy='1 + 1',表达式为"1 + 1")。

      • arg:传给指令的参数(如:v-copy:dblclick中,arg的值为dblclick)。

      • modifiers:一个包含修饰符的对象(如:v-copy.dblclick.icon中,修饰符对象为:{dblclick: true, icon: true})。

    • vnode:Vue编译生成的虚拟节点。

    • oldVnode:上一个虚拟节点。仅在update和componentUpdated钩子函数中可用。

    实际使用

    复制指令(v-copy)

    我们先看如何使用:

    单击复制
    <div v-copy>单击复制</div> // 默认复制div的文案<div v-copy="copyStr">单击复制</div> // 复制指令里的内容(copyStr)

    给el添加点击事件,判断binding的value值是否为空,若为空,默认获取绑定元素的文本内容

    el.addEventListener("click", () => {    let str = binding.value ? binding.value : el.innerText;    handleClick(str);});el.style.cursor = "copy";
    双击复制
    <div v-copy:dblclick>双击复制</div> // 默认复制div的文案<div v-copy:dblclick="copyStr">双击复制</div> // 复制指令里的内容(copyStr)

    给el添加双击事件,判断binding的value值是否为空,若为空,默认获取绑定元素的文本内容

    el.addEventListener("dblclick", () => {    let str = binding.value ? binding.value : el.innerText;    handleClick(str);});el.style.cursor = "copy";
    点击icon复制
    <div v-copy:icon>单击icon复制</div> // 默认复制div的文案<div v-copy:icon="copyStr">单击icon复制</div> // 复制指令里的内容(copyStr)

    判断el是否已经增加了icon,没有则增加i标签,放置icon,给icon增加点击事件,进行复制

    if (el.hasIcon) return;const iconElement = document.createElement("i");iconElement.setAttribute("class", "el-icon-document-copy");iconElement.setAttribute("style", "margin-left:5px");el.appendChild(iconElement);el.hasIcon = true;iconElement.addEventListener("click", () => {    let str = binding.value ? binding.value : el.innerText;    handleClick(str);});iconElement.style.cursor = "copy";
    handleClick 逻辑

    判断是否有id为copyTarget的输入框,没有则创造一个id为copyTarget的输入框,然后进行选中,调用execCommand('copy')进行选中文字的复制。

    function handleClick (text) {    if (!document.getElementById("copyTarget")) {        const copyTarget = document.createElement("input");        copyTarget.setAttribute("id", "copyTarget");        copyTarget.setAttribute("style", "position:fixed;top:0;left:0;opacity:0;z-index:-1000;");        document.body.appendChild(copyTarget);    }    // 复制内容    const input = document.getElementById("copyTarget");    input.value = text;    input.select(); // 选取文本域中的内容。    // 调用execCommand()可以实现浏览器菜单的很多功能. 如保存文件,打开新文件,撤消、重做操作…    document.execCommand("copy"); // 复制选中的文字到剪贴板;    // Message.success("复制成功");    Notification({        title: "成功",        message: `${text}已复制到剪切板`,        type: "success"    });}
    完整代码
    import { Message, Notification } from "element-ui";function handleClick (text) {    if (!document.getElementById("copyTarget")) {        const copyTarget = document.createElement("input");        copyTarget.setAttribute("id", "copyTarget");        copyTarget.setAttribute("style", "position:fixed;top:0;left:0;opacity:0;z-index:-1000;");        document.body.appendChild(copyTarget);    }    // 复制内容    const input = document.getElementById("copyTarget");    input.value = text;    input.select(); // 选取文本域中的内容。    // 调用execCommand()可以实现浏览器菜单的很多功能. 如保存文件,打开新文件,撤消、重做操作…    document.execCommand("copy"); // 复制选中的文字到剪贴板;    // Message.success("复制成功");    Notification({        title: "成功",        message: `${text}已复制到剪切板`,        type: "success"    });}const install = function (Vue) {    Vue.directive("copy", {        bind (el, binding) {            if (binding.arg === "dblclick") { // 双击触发                el.addEventListener("dblclick", () => {                    let str = binding.value ? binding.value : el.innerText;                    handleClick(str);                });                el.style.cursor = "copy";            } else if (binding.arg === "icon") { // 点击icon触发                if (el.hasIcon) return;                const iconElement = document.createElement("i");                iconElement.setAttribute("class", "el-icon-document-copy");                iconElement.setAttribute("style", "margin-left:5px");                el.appendChild(iconElement);                el.hasIcon = true;                iconElement.addEventListener("click", () => {                    let str = binding.value ? binding.value : el.innerText;                    handleClick(str);                });                iconElement.style.cursor = "copy";            } else { // 单击触发                el.addEventListener("click", () => {                    let str = binding.value ? binding.value : el.innerText;                    handleClick(str);                });                el.style.cursor = "copy";            }        }    });};export default install;

    权限操作指令(v-hasPermi)

    • 使用:<el-button v-hasPermi="['activity:school:add']">新增活动</el-button>

    • 从store获取用户的权限数组,判断此时binding的value值是否存在权限数组中,没有则进行按钮的隐藏。

    • 完整代码

    import store from "@/store";const allPermission = "*:*:*";export function hasPermi(value){    // return true;    const permissions = store.getters && store.getters.permissions;    if (value && value instanceof Array && value.length > 0) {        const permissionFlag = value;        const hasPermissions = permissions.some(permission => allPermission === permission || permissionFlag.includes(permission));        if (!hasPermissions) {            return false;        }        return true;    }    throw new Error("请设置操作权限标签值");}export default {    inserted(el, binding) {        const { value } = binding;        if (!hasPermi(value)){            el.parentNode && el.parentNode.removeChild(el);        }    }};

    到此,相信大家对“vue自定义封装指令及实际使用的方法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    --结束END--

    本文标题: vue自定义封装指令及实际使用的方法

    本文链接: https://www.lsjlt.com/news/321388.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • c#怎么判断文件夹是否存在
      如何用 c# 判断文件夹是否存在?使用 directory.exists 方法,指定文件夹路径,获取布尔值判断是否存在。若不存在,使用 directory.createdirectory...
      99+
      2024-05-14
      c#
    • c#文件路径引用变量怎么写
      在 c# 中,您可以通过字符串插值或 string.format 方法将变量引用到文件路径中。字符串插值使用 ${} 语法,而 string.format 方法需要提供格式字符串和要插入...
      99+
      2024-05-14
      c#
    • C++ 原子库的使用和限制
      c++++ 原子库提供线程安全的数据类型,以确保数据原子性。原子变量是不可中断的,并且提供了广泛的原子操作,包括加、减和交换。常见的类型包括 std::atomic 和 std::ato...
      99+
      2024-05-14
      c++ 原子库
    • c#中怎么定义全局变量
      在 c# 中定义全局变量:在类或方法外声明,使用语法:access_modifier type variable_name;可用 access_modifier 修饰符:public、p...
      99+
      2024-05-14
      access c#
    • c#怎么调用另一个类的方法
      在 c# 中调用另一个类的方法有三种方式:直接调用:创建该类的实例,然后使用实例调用方法。通过接口调用:创建接口,定义要调用的方法;创建实现该接口的类;使用接口创建类的实例,然后通过接口...
      99+
      2024-05-14
      c#
    • C++ 服务器架构的未来发展趋势和最佳实践
      未来c++++服务器架构趋势包括:异步和非阻塞编程可提升性能;微服务架构提高可扩展性和灵活性;云原生设计带来无状态性和可观测性。最佳实践包括:使用libcuckoo优化数据存储;采用tc...
      99+
      2024-05-14
      c++ 服务器架构 docker 高可扩展性
    • c#多线程访问同一变量应该怎么解决
      解决 c# 多线程访问同一变量的问题的方法如下:使用锁(lock)使用互斥体(mutex)使用自旋锁(spinlock)使用原子操作 处理 C# 多线程访问同一变量问题 多线程编程中,...
      99+
      2024-05-14
      c# 同步机制
    • c#数据表怎么建立时间列
      在 c# datatables 中创建时间列只需 4 个步骤:创建 datatable。创建并指定 datetime 类型的 datacolumn。将 datacolumn 添加到 da...
      99+
      2024-05-14
      c#
    • c#怎么把类实例化
      在c#中,实例化一个类是创建一个类的对象,使用new关键字,如:类名 对象名 = new 类名()。构造函数是实例化类时调用的特殊方法,用于初始化属性,如:public person(s...
      99+
      2024-05-14
      c#
    • PHP数据结构:链表的魅力,探索动态数据组织
      链表是一种数据结构,采用一系列带有数据和指针的节点组织元素,特别适合处理大型数据集和频繁的插入/删除操作。它的基本组成部分包括节点(数据和指向下一个节点的指针)和头节点(指向链表中第一个...
      99+
      2024-05-14
      php 链表
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作