国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Vue實現簡單的拖拽效果

瀏覽:89日期:2022-12-03 16:14:19

本文實例為大家分享了Vue實現簡單拖拽效果的具體代碼,供大家參考,具體內容如下

自定義指令v-drag

l 存在時 只能橫向拖拽

t 存在時 只能縱向拖拽

lt都存在時 可以任意方向拖拽

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1.0'> <meta http-equiv='X-UA-Compatible' content='ie=edge'> <title>拖拽</title> <style> *{ margin: 0; padding: 0; } #box{ background: red; width: 100px; height: 100px; position: absolute; } </style> <script src='http://www.intensediesel.com/bcjs/vue.js'></script></head><body> <div id='app'> <div v-drag.l.t='flag'></div> </div> <script> Vue.directive('drag',(el,{modifiers,value})=>{ let{l,t}=modifiers; el.addEventListener('mousedown',handleDownCb) let disX,disY; function handleDownCb(e){ disX=e.offsetX; disY=e.offsetY; // console.log(disX,disY) document.addEventListener('mousemove',handleMoveCb); document.addEventListener('mouseup',handleUpCb); } function handleMoveCb(e){ let x=e.clientX-disX; let y=e.clientY-disY; if((l&&t) && value){ el.style.left=x+'px'; el.style.top=y+'px'; return; } if(l&&value){ el.style.left=x+'px'; return; } if(t&&value){ el.style.top=y+'px'; return; } } function handleUpCb(){ document.removeEventListener('mousemove',handleMoveCb); document.removeEventListener('mouseup',handleUpCb); } }) let vm=new Vue({ el:'#app', data:{ flag:true } }) </script></body></html>

注:

改變v-drag.l v-drag.t v-drag.l.t 即可實現橫向 縱向 任意方向的拖拽

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 峡江县| 广元市| 辛集市| 老河口市| 乐亭县| 普兰县| 新邵县| 中江县| 武功县| 九龙坡区| 松潘县| 禹城市| 石楼县| 扬中市| 旬阳县| 夏津县| 贡山| 鹤山市| 东乡| 陵水| 无为县| 上杭县| 咸宁市| 闽侯县| 郎溪县| 宣化县| 临城县| 滦平县| 融水| 蒙山县| 文成县| 平顶山市| 常熟市| 青神县| 临朐县| 天等县| 石阡县| 甘孜| 米林县| 玛多县| 鄯善县|