拖拽效果

需要提前了解的

  • 运动都需要定位的支持,所以如果想实现拖拽,拖拽目标必须设置position为定位属性。
  • 事件源 拖拽需要用到事件源 mouseEvent
image.png

其中clientX clientY相对于浏览器窗口,offsetX offsetY相对于父元素。

  • 三个事件:onmousedown、onmousemove、onmouseup

实现思路:

1:给目标元素添加onmousedown事件,拖拽的前提是在目标元素按下鼠标左键。
2:当onmousedown发生以后,此刻给document添加onmousemove事件,意味着此刻鼠标在网页的移动都将改变目标元素的位置。
3:在onmousemove事件中,设定目标元素的left和top,公式:
目标元素的left = 鼠标的clientX – (鼠标和元素的横坐标差,即offsetX)
目标元素的top = 鼠标的clientY– (鼠标和元素的纵坐标差,即offsetY)。
4:当onmousedown发生以后,此刻给document添加onmouseup事件,意味着此刻鼠标在网页的任意位置松开鼠标,都会放弃拖拽的效果。
5:在onmouseup事件中,取消document的onmousemove事件即可。

具体代码

var div = document.getElementsByTagName('div')[0];
div.onmousedown = function (event1) {
    // 鼠标按下的时候开始拖拽
    //记录鼠标 在div 中的偏移
    var evt1 = window.event || event1;
    var offsetY = evt1.pageY - div.offsetTop;
    var offsetX = evt1.pageX - div.offsetLeft;

    //监听鼠标在文档中的移动
    document.onmousemove = function (event) {
        //改变 div 的坐标
        //根据鼠标坐标计算出 div 的坐标
        var evt = event || window.event;
        console.log(evt.pageX,evt.pageY);

        var divLeft = evt.pageX -offsetX;
        var divTop = evt.pageY - offsetY;

        var width = document.body.clientWidth || document.documentElement.clientWidth;
        var height = document.body.clientHeight || document.documentElement.clientHeight;

        //边界处理
        if(divTop >=0 && divTop <=  height - div.offsetHeight){
            div.style.top = divTop +'px';
        }
        if(divLeft >=0 && divLeft <=  width - div.offsetWidth){
            div.style.left  = divLeft +'px';//px
        }
    }
    document.onmouseup = function () {
        document.onmousemove = null;
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 鼠标拖拽效果分为3个事件 鼠标按下事件onmousedown, 事件源是点击的对象, 就是我们要拖拽的对象 鼠标移...
    LiYajie阅读 1,352评论 0 1
  • 鼠标事件 与鼠标相关的事件如图所示,除了'mouseenter'和'mouseleave'外的所有鼠标事件都能冒泡...
    angryyan阅读 3,637评论 0 3
  • 当产品间需要交互实现数据传递,或产品需要从外部导入文件时,通过控件拖拽来实现是个不错的选择。在UI上支持控件拖拽,...
    BarretX阅读 11,392评论 0 2
  • 最近新学了拖拽效果,没有好记性,只好用烂笔头记录一下了。首先讲讲拖拽的思路(只分析水平方向,垂直方向类似): 首先...
    詹小云阅读 1,432评论 0 6
  • 如果我想跟你说说话,是否非得要求你一定就得有回应?或者难道不应该有回应么?我为什么喜欢你,很重要的一点就是无论什么...
    我不是许方阅读 117评论 0 0