电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Vue使用自定義指令實(shí)現(xiàn)拖拽行為實(shí)例分析

瀏覽:43日期:2023-01-15 09:37:28

本文實(shí)例講述了Vue使用自定義指令實(shí)現(xiàn)拖拽行為。分享給大家供大家參考,具體如下:

需求

通過(guò)自定義指令的方式實(shí)現(xiàn)拖拽效果,預(yù)期的使用方式為:

<div v-drag> XXXX</div>

更重要的一個(gè)需求點(diǎn):

拖拽元素內(nèi)部的子元素可以自行阻止拖拽行為

比如:

<div v-drag> <el-button @mousedown.native.stop>test</el-button></div>

曾經(jīng)使用過(guò)vue-resizable,由于該組件是通過(guò)事件捕獲的方式實(shí)現(xiàn)的,拖拽元素的子元素也會(huì)觸發(fā)拖拽行為,不符合開(kāi)發(fā)需求,所以自行實(shí)現(xiàn)了拖拽指令,相關(guān)源碼如下。

無(wú)任何依賴,復(fù)制即可使用

源碼

/** * @file 自定義拖拽命令 */import Vue from ’vue’;const Drag = { install(Vue: any) { // 如需禁止拖拽元素內(nèi)部某些元素觸發(fā)拖拽,在內(nèi)部不可觸發(fā)拖拽元素上添加@mousedown.native.stop即可 Vue.directive(’drag’, { bind(el: any) {el.style.position = ’absolute’;el.style.zIndex = el.style.zIndex || ’3000’; }, inserted(el: any) {// 設(shè)置元素初始位置const boundingClientRect = el.getBoundingClientRect();el.style.left = boundingClientRect.x + ’px’;el.style.top = boundingClientRect.y + ’px’;// 將拖拽元素置于body子元素,防止被relative的父元素遮擋document.body.appendChild(el);let originX: number;let originY: number;const mouseDownHandler = (evt: MouseEvent) => { originX = evt.clientX - el.offsetLeft; originY = evt.clientY - el.offsetTop; el.style.cursor = ’pointer’;};const mouseMoveHandler = (evt: MouseEvent) => { if (evt.buttons === 1 && originX && originY) { el.style.left = evt.clientX - originX + ’px’; el.style.top = evt.clientY - originY + ’px’; }};const mouseUpHandler = () => { el.style.cursor = ’default’;};el.addEventListener(’mousedown’, mouseDownHandler);el.addEventListener(’mousemove’, mouseMoveHandler);el.addEventListener(’mouseup’, mouseUpHandler);el.__mouseDownHandler__ = mouseDownHandler;el.__mouseMoveHandler__ = mouseMoveHandler;el.__mouseUpHandler__ = mouseUpHandler; }, unbind(el: any) {el.removeEventListener(’mousedown’, el.__mouseDownHandler__);el.removeEventListener(’mousemove’, el.__mouseMoveHandler__);el.removeEventListener(’mouseup’, el.__mouseUpHandler__);// 當(dāng)父組件銷毀觸發(fā)unbind的時(shí)候需要手動(dòng)刪除這個(gè)節(jié)點(diǎn),不然會(huì)一直存留在body中el.parentNode.removeChild(el); } }); }};Vue.use(Drag);export default Drag;

希望本文所述對(duì)大家vue.js程序設(shè)計(jì)有所幫助。

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 真石漆,山东真石漆,真石漆厂家,真石漆价格-山东新佳涂料有限公司 | 无菌水质袋-NASCO食品无菌袋-Whirl-Pak无菌采样袋-深圳市慧普德贸易有限公司 | 美名宝起名网-在线宝宝、公司、起名平台 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 加气混凝土砌块设备,轻质砖设备,蒸养砖设备,新型墙体设备-河南省杜甫机械制造有限公司 | 卡诺亚轻高定官网_卧室系统_整家定制_定制家居_高端定制_全屋定制加盟_定制家具加盟_定制衣柜加盟 | 油冷式_微型_TDY电动滚筒_外装_外置式电动滚筒厂家-淄博秉泓机械有限公司 | 运动木地板价格,篮球馆体育运动木地板生产厂家_欧氏地板 | 双吸泵,双吸泵厂家,OS双吸泵-山东博二泵业有限公司 | 粘度计NDJ-5S,粘度计NDJ-8S,越平水分测定仪-上海右一仪器有限公司 | 冷柜风机-冰柜电机-罩极电机-外转子风机-EC直流电机厂家-杭州金久电器有限公司 | 消泡剂_水处理消泡剂_切削液消泡剂_涂料消泡剂_有机硅消泡剂_广州中万新材料生产厂家 | 云南丰泰挖掘机修理厂-挖掘机维修,翻新,再制造的大型企业-云南丰泰工程机械维修有限公司 | 云杂志网-学术期刊-首页 | 世纪豪门官网 世纪豪门集成吊顶加盟电话 世纪豪门售后电话 | 深圳市源和塑胶电子有限公司-首页 | 南京和瑞包装有限公司| 制氮设备-变压吸附制氮设备-制氧设备-杭州聚贤气体设备制造有限公司 | 安徽合肥格力空调专卖店_格力中央空调_格力空调总经销公司代理-皖格制冷设备 | 烘干设备-热泵烘干机_广东雄贵能源设备有限公司 | 压砖机_电动螺旋压力机_粉末成型压力机_郑州华隆机械tel_0371-60121717 | 安平县鑫川金属丝网制品有限公司,声屏障,高速声屏障,百叶孔声屏障,大弧形声屏障,凹凸穿孔声屏障,铁路声屏障,顶部弧形声屏障,玻璃钢吸音板 | 全自动在线分板机_铣刀式在线分板机_曲线分板机_PCB分板机-东莞市亿协自动化设备有限公司 | 创客匠人-让IP变现不走弯路| 整车VOC采样环境舱-甲醛VOC预处理舱-多舱法VOC检测环境仓-上海科绿特科技仪器有限公司 | 喷码机,激光喷码打码机,鸡蛋打码机,手持打码机,自动喷码机,一物一码防伪溯源-恒欣瑞达有限公司 | 芝麻黑-芝麻黑石材厂家-永峰石业 | 餐饮加盟网_特色餐饮加盟店_餐饮连锁店加盟 | 信阳网站建设专家-信阳时代网联-【信阳网站建设百度推广优质服务提供商】信阳网站建设|信阳网络公司|信阳网络营销推广 | 成都LED显示屏丨室内户外全彩led屏厂家方案报价_四川诺显科技 | 2025第九届世界无人机大会| 济南品牌包装设计公司_济南VI标志设计公司_山东锐尚文化传播 | 嘉兴恒升声级计-湖南衡仪声级计-杭州爱华多功能声级计-上海邦沃仪器设备有限公司 | 无锡网站建设_小程序制作_网站设计公司_无锡网络公司_网站制作 | 餐饮加盟网_特色餐饮连锁加盟店-餐饮加盟官网 | 深圳市超时尚职业培训学校,培训:月嫂,育婴,养老,家政;化妆,美容,美发,美甲. | 原色会计-合肥注册公司_合肥代理记账公司_营业执照代办 | 制冷采购电子商务平台——制冷大市场 | 胶辊硫化罐_胶鞋硫化罐_硫化罐厂家-山东鑫泰鑫智能装备有限公司 意大利Frascold/富士豪压缩机_富士豪半封闭压缩机_富士豪活塞压缩机_富士豪螺杆压缩机 | SPC工作站-连杆综合检具-表盘气动量仪-内孔缺陷检测仪-杭州朗多检测仪器有限公司 | 高柔性拖链电缆-聚氨酯卷筒电缆-柔性屏蔽电缆厂家-玖泰电缆 |