我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

本篇内容主要讲解“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自定义封装指令及实际使用的方法”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

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

    下载Word文档

    猜你喜欢

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

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

    Vue自定义指令及使用实例

    这篇文章主要介绍了Vue自定义指令及使用实例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、什么是指令学习 vue 的时候肯定会接触指令,那么什么是指令呢?在 vue 中提
    2023-06-15

    Vue自定义指令directive的使用方法分享

    这篇文章主要为大家详细介绍了Vue中自定义指令directive的使用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-05-15

    vue自定义指令使用的方法是什么

    这篇“vue自定义指令使用的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“vue自定义指令使用的方法是什么”文章吧
    2023-07-05

    vue自定义指令directive使用的方法是什么

    本篇内容主要讲解“vue自定义指令directive使用的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue自定义指令directive使用的方法是什么”吧!1. 一个指令定义对象可
    2023-07-06

    Vue自定义指令的使用实例介绍

    作为使用Vue的开发者,我们对Vue指令一定不陌生,诸如v-model、v-on、等,同时Vue也为开发者提供了自定义指令的api,熟练的使用自定义指令可以极大的提高了我们编写代码的效率,让我们可以节省时间开心的摸鱼
    2023-05-16

    浅析vue中的自定义指令使用

    最近做的项目,用了很多 Vue 的自定义指令,在同事等小伙伴之间调研发现,很多人几乎都不用 Vue 提供的这个能力。所以就把自己的一些使用方式整理一下分享给小伙伴,让大家也不要忽略自定义指令这个能力
    2023-05-14

    vue自定义指令directive的使用场景

    这篇文章主要详细介绍了vue自定义指令directive的使用场景,文中有详细的代码示例,感兴趣的小伙伴欢迎阅读
    2023-05-16

    vue中的自定义指令如何使用

    这篇文章主要介绍“vue中的自定义指令如何使用”,在日常操作中,相信很多人在vue中的自定义指令如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中的自定义指令如何使用”的疑惑有所帮助!接下来,请跟
    2023-06-29

    Vue中的自定义指令有哪些及怎么使用

    本篇内容主要讲解“Vue中的自定义指令有哪些及怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue中的自定义指令有哪些及怎么使用”吧!1、什么是自定义指令vue 官方提供了 v-text
    2023-06-30

    Vue实用的自定义指令有哪些

    这篇文章主要讲解了“Vue实用的自定义指令有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue实用的自定义指令有哪些”吧!前言:Vue自定义指令有全局注册和局部注册两种方式。先来看看注
    2023-06-29

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录