vue 开发一个长按指令

君哥 阅读:1503 2020-02-07 12:36:50 评论:0

原理 

要实现长按,用户需要按下并按住按钮几秒钟。

想通过代码模拟这一效果,我们需要在鼠标“点击”按下按钮时,启动一个计时器监听用户按下的时长,如果时间超过我们期望的时长,就执行相应的函数。


指令代码

// longpress.js    
export default {    
install(Vue, options = {    
time: 500    
}) {    
Vue.directive('longpress', {        
bind: function(el, binding, vNode) {            
// 确保提供的表达式是函数            
if (typeof binding.value !== 'function') {                
// 获取组件名称                
const compName = vNode.context.name;                
// 将警告传递给控制台                
let warn = `[longpress:] provided expression '${binding.expression}' is not afunction, but has to be `;    
if (compName) { warn += `Found in component '${compName}' `}    
console.warn(warn);    
}          
// 定义变量    
let pressTimer = null;    
// 定义函数处理程序    
// 创建计时器( 1秒后执行函数 )    
let start = (e) => {    
if (e.type === 'click' && e.button !== 0) {    
return;    
}    
if (pressTimer === null) {    
pressTimer = setTimeout(() => {    
// 执行函数    
handler();    
}, options.time)    
}    
}    
// 取消计时器    
let cancel = () => {    
// 检查计时器是否有值    
if ( pressTimer !== null ) {    
clearTimeout(pressTimer);    
pressTimer = null;    
}    
}            
// 运行函数    
const handler = (e) => {    
// 执行传递给指令的方法    
binding.value(e)    
};    
// 添加事件监听器    
el.addEventListener("mousedown", start);    
el.addEventListener("touchstart", start);    
// 取消计时器    
el.addEventListener("click", cancel);    
el.addEventListener("mouseout", cancel);    
el.addEventListener("touchend", cancel);    
el.addEventListener("touchcancel", cancel);    
}    
})    
}    
}


main.js 中引入注册

import LongPress from './longpress.js' 
 Vue.use(LongPress, {time: 500})


本文链接:https://www.yanjun202.com/post/61.html 

分享到:
可以去百度分享获取分享代码输入这里。
发表评论
搜索
排行榜
关注我们

扫一扫关注我们,了解最新精彩内容