Vue實(shí)現(xiàn)簡(jiǎn)單的拖拽效果
本文實(shí)例為大家分享了Vue實(shí)現(xiàn)簡(jiǎ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.gepszalag.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)橫向 縱向 任意方向的拖拽
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Django使用HTTP協(xié)議向服務(wù)器傳參方式小結(jié)2. Java web Hibernate如何與數(shù)據(jù)庫鏈接3. 強(qiáng)烈推薦一個(gè)基于.Net Framework開發(fā)的Windows右鍵菜單管理工具4. jQuery+PHP實(shí)現(xiàn)圖片上傳并提交功能5. vue實(shí)現(xiàn)給div綁定keyup的enter事件6. tomcat共享多個(gè)web應(yīng)用會(huì)話的實(shí)現(xiàn)方法7. JSP登錄中Session的用法實(shí)例詳解8. Python如何實(shí)現(xiàn)的簡(jiǎn)單購(gòu)物車程序9. asp中Request.ServerVariables的參數(shù)集合10. ajax實(shí)現(xiàn)提交時(shí)校驗(yàn)表單方法
