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

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

Vue實(shí)現(xiàn)簡單的拖拽效果

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

本文實(shí)例為大家分享了Vue實(shí)現(xiàn)簡單拖拽效果的具體代碼,供大家參考,具體內(nèi)容如下

自定義指令v-drag

l 存在時(shí) 只能橫向拖拽

t 存在時(shí) 只能縱向拖拽

lt都存在時(shí) 可以任意方向拖拽

<!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 即可實(shí)現(xiàn)橫向 縱向 任意方向的拖拽

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 厦门市| 建水县| 林周县| 聂拉木县| 连江县| 新津县| 潼关县| 兴和县| 佛学| 诏安县| 台湾省| 大理市| 古田县| 舞阳县| 延津县| 宜春市| 张家口市| 桑植县| 左权县| 东兴市| 台中县| 武川县| 汾西县| 佳木斯市| 和田县| 枣强县| 吐鲁番市| 鹤壁市| 达拉特旗| 新巴尔虎左旗| 灵川县| 隆化县| 云和县| 五寨县| 平舆县| 上高县| 石阡县| 永吉县| 漳州市| 光山县| 庆元县|