IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue中可能会用到的自定义指令 -> 正文阅读

[JavaScript知识库]Vue中可能会用到的自定义指令

自定义指令

Vue允许注册自定义指令,它的作用是在某些场景下对于DOM元素进行操作

Vue注册全局指令通过Vue.directive( id, [definition] )的方式来完成,然后在入口文件中使用Vue.use()来调用

指令定义函数提供了几个钩子函数:

  1. bind:只调用一次,第一次绑定到元素时调用
  2. inserted:被绑定元素在插入父节点的时候调用,父节点只要存在就可以调用,不必存在于document中
  3. update:被绑定的元素所在的模板更新的时候调用,不论绑定值是否改变
  4. componentUpdated:被绑定元素所在模板完成一次更新周期时调用
  5. unbind:只调用一次,指令与元素解绑时调用

如果自定义指令比较多,可以批量注册指令

新建directive/index.js文件,代码如下:

import longpress from "./longpress.js";
import copy from "./copy.js";

//自定义指令的对象,只需要引入后在这里添加就可以了
const directives = {
    longpress,
	copy,
}

export default {
    install(Vue) {
        Object.keys(directives).forEach((key) => {
            Vue.directive(key, directives[key]);
        })
    },
}

然后在入口文件main.js中调用

import directives from '@/directive/index.js'
Vue.use(directives);

1.长按指令(v-longpress)

长按几秒触发执行相应操作

longpress.js文件代码:

const longpress = {
    bind: function (el, binding, vNode) {
        //判断传入的回调是否为函数
        if (typeof binding.value !== "function") {
            throw "callback must be a function"
        }
        //长按时间
        let pressTime = null;
        //创建定时器,两秒之后执行
        let start = (e) => {
            if (e.type === "click" && e.button !== 0) {
                return
            }
            if (pressTime === null) {
                pressTime = setTimeout(() => {
                    handler();
                }, 1000);
            }
        }
        //取消定时器
        let cancle = (e) => {
            if (pressTime !== null) {
                clearTimeout(pressTime);
                pressTime = null;
            }
        }
        //运行函数
        const handler = (e) => {
            binding.value(e);
        }
        //添加事件监听
        el.addEventListener("mousedown", start);
        el.addEventListener("touchstart", start);
        //取消计时器
        el.addEventListener("click", cancle);
        el.addEventListener("mouseout", cancle);
        el.addEventListener("touchend", cancle);
        el.addEventListener("touchcancel", cancle);
    },
    //传入的值更新的时候触发
    componentUpdated(el, { value }) {
        el.$value = value
    },
    // 指令与元素解绑的时候,移除事件绑定
    unbind(el) {
        el.removeEventListener("click", el.handler)
    },
}

export default longpress;

使用:给需要的操作的元素加上v-longpress以及回调即可

<template>
  <div>
    <div style="width: 100px; height: 100px; background-color: red"
      v-longpress="longpress">
      长按触发指令
    </div>
  </div>
</template>

<script>
export default {
  name: "longpress",
  methods: {
    longpress() {
      alert("长按指令生效");
    },
  },
};
</script>

2.一键复制文本内容(v-copy)

copy.js代码:

const copy = {
	bind(el, { value }) {
		el.$value = value;
		el.handle = () => {
			if (!el.$value) {
				//值为空的时候不复制并给出提示,并退出
				alert("暂无复制内容");
				return
			}
			//动态创建textarea标签
			const textarea = document.createElement("textarea");
			//将此textarea设为readonly,防止ios下自动唤起键盘,同时将textarea移出可视区域
			textarea.readOnly = "readonly";
			textarea.style.position = "absolute";
			textarea.style.left = "-9999px";
			//将值复制给textarea的value属性
			textarea.value = el.$value;
			//插入到页面中
			document.body.appendChild(textarea);
			//选中值并复制
			textarea.select();
			const result = document.execCommand('Copy');
			if (result) {
				alert("复制成功");
			}
			//移除textarea
			document.body.removeChild(textarea);
		}
		//绑定事件
		el.addEventListener("click", el.handle);
	},
	//传入的值更新的时候触发
	componentUpdated(el, { value }) {
		el.$value = value;
	},
	unbind(el) {
		el.removeEventListener("click", el.handle);
	},
}

export default copy

使用:给元素加上v-copy指令

<template>
  <div>
    <input class="text" type="text" v-model="copytext" />
    <button style="margin-left: 20px" v-copy="copytext">复制</button>
    <span>{{ copytext }}</span>
  </div>
</template>

<script>
export default {
  name: "copy",
  data() {
    return {
      copytext: null,
    };
  },
};
</script>

防抖指令

debounce.js代码:

const debounce = {
    inserted(el, binding) {
        let timer;
        el.addEventListener("click", () => {
            if (timer) {
                clearTimeout(timer);
            }
            let callNow = !timer;
            timer = setTimeout(() => {
                timer = null;
            }, 1000);
            if (callNow) {
                binding.value();
            }
        });
    }
}

export default debounce

使用:给需要操作的元素加上v-debounce指令

<template>
  <div>
    <button class="btn" v-debounce="clickHandle">点击事件防抖</button>
  </div>
</template>

<script>
export default {
  name: "debounce",
  methods: {
    clickHandle() {
      console.log("触发了点击事件");
    },
  },
};
</script>

最后附上gitee地址:https://gitee.com/ywx_jd/custom-directive.

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-20 15:00:21  更:2021-08-20 15:01:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/27 6:55:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码
数据统计