Vue實(shí)現(xiàn)簡單的拖拽效果
本文實(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)。
相關(guān)文章:
1. IntelliJ IDEA導(dǎo)出項(xiàng)目的方法2. idea設(shè)置提示不區(qū)分大小寫的方法3. 40個(gè)Java集合面試問題和答案4. Spring如何集成ibatis項(xiàng)目并實(shí)現(xiàn)dao層基類封裝5. IDEA 2020.1.2 安裝教程附破解教程詳解6. django queryset相加和篩選教程7. Java利用TCP協(xié)議實(shí)現(xiàn)客戶端與服務(wù)器通信(附通信源碼)8. ajax實(shí)現(xiàn)頁面的局部加載9. 利用ajax+php實(shí)現(xiàn)商品價(jià)格計(jì)算10. JavaScript實(shí)現(xiàn)組件化和模塊化方法詳解

網(wǎng)公網(wǎng)安備