本篇文章为大家展示了如何实现vue模块拖拽效果,代码简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
成都创新互联公司-专业网站定制、快速模板网站建设、高性价比千阳网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式千阳网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖千阳地区。费用合理售后完善,十余年实体公司更值得信赖。正巧在之前面试中遇到问实现拖拽效果
当时面试的时候简单回答了实现的方式与逻辑。
现在闲来无事,把这个东西实现了一下。
原理很简单,写的很方便。
数据驱动,建立一个数组,数组初始长度为1
拖动触发时,添加一个对象到数组中,拖动的是下标为0的对象,新建的还在原来位置放着,等待下次拖动。
话不多说,上代码
<template> <div> <div @mousedown="move($event,index)" v-for="(x,index) in i"> <span v-if="index+1 !== i.length">{{index+1}}</span> <input v-model="x.input"> </div> {{i}} </div> </template> <script> export default { name: "index", data(){ return{ positionX:0, positionY:0, i:[ {input:''} ] } }, methods:{ move(e,x){ let odiv = e.target; //获取目标元素 //算出鼠标相对元素的位置 let disX = e.clientX - odiv.offsetLeft; let disY = e.clientY - odiv.offsetTop; let flag = true; document.onmousemove = (e)=>{ //鼠标按下并移动的事件 if(flag && x === this.i.length-1){ flag = false; this.i.push({input:''}) } //用鼠标的位置减去鼠标相对元素的位置,得到元素的位置 let left = e.clientX - disX; let top = e.clientY - disY; //绑定元素位置到positionX和positionY上面 this.positionX = top; this.positionY = left; //移动当前元素 odiv.style.left = left + 'px'; odiv.style.top = top + 'px'; }; document.onmouseup = (e) => { document.onmousemove = null; document.onmouseup = null; }; } } } </script> <style scoped> .view{ position: absolute; top: 0; bottom: 0; left: 0; right: 0; background: #f8f8f8; .x{ width: 250px; height: 50px; top: 50px; left: 10px; position: absolute; background: red; color: yellow; } } </style>
一个简单的demo,后续用的话可以再丰富,比如以拖动长度来触发事件。
input可以换成子组件。这里提供分享一个底层的实现方式
input可以换成子组件。这里提供分享一个底层的实现方式
上述内容就是如何实现vue模块拖拽效果,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联网站制作公司行业资讯频道。
名称栏目:如何实现vue模块拖拽效果-创新互联
网站路径:https://www.cdcxhl.com/article4/pcjoe.html
成都网站建设公司_创新互联,为您提供企业建站、做网站、Google、自适应网站、网站维护、网站改版
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联