码迷,mamicode.com
首页 > 其他好文 > 详细

vue实现拖动div元素

时间:2017-12-06 18:09:11      阅读:602      评论:0      收藏:0      [点我收藏+]

标签:html   drag   red   实现   offset   use   new   pagex   page   

html:

<div id="app1">
     <div v-drag class="drag"></div>
     <div v-drag class="drag"></div>
</div>

css:

.drag{
            width: 100px;
            height: 100px;
            position: absolute;
            top: 0;
            left: 0;
            background-color: red;
}

js:

    // 拖动div元素
    let vm1 = new Vue({
        el:‘#app1‘,
        // 自定义指令
        directives:{
            drag(el,bindings){
                el.onmousedown = function(e){
                    var disx = e.pageX - el.offsetLeft;
                    var disy = e.pageY - el.offsetTop;
                    document.onmousemove = function (e){
                        el.style.left = e.pageX - disx+‘px‘;
                        el.style.top = e.pageY - disx+‘px‘;
                    }
                    document.onmouseup = function(){
                        document.onmousemove = document.onmouseup = null;
                    }
                }
            }
        }
    })

 

vue实现拖动div元素

标签:html   drag   red   实现   offset   use   new   pagex   page   

原文地址:http://www.cnblogs.com/huahua0825/p/7993141.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!