鼠标拖动效果。支持以absolute、fixed、relative、float定位的元素。

note

下载

使用

示例1

 var dispose1 = drag('#drag1');                             //传入选择器
 var dispose2 = drag(document.getElementById('drag2'));     //传入元素节点
 var dispose3 = drag('#drag3',{ proxy:true });              //传入配置参数。

demo

http://wangwl.net/static/demo/wwl-drag/demo.html

函数签名

function drag( node, options )

函数返回值

var dispose = drag('#drag');
typeof dispose === 'function';  //true

drag()的返回值是function类型,用于释放资源(取消事件监听等)。

例如,在Vue的beforeDestroy和React的componentWillUnmount中需要调用dispose()

options参数

{ container, targetContainer, handler, proxy, posProperty, event:{dragActive,dragStart,dragMove,dragEnd} }

container

{element|string} 元素节点或选择器。

指定拖动的容器,限制拖动元素只能在该容器中被拖动。

默认为 document.body,即拖动元素只能在该文档中拖动。

传入字符串"null",则不限制范围。

//documentElement和null的区别:

/*
<style> 
#drag1,#drag2{ 
    left:0;
    position:absolute; 
    width:50px; 
    height:50px; 
    border:1px solid #000;} 
</style>
<body>
    <div id=drag1></div>
    <div id=drag1></div>
</body>
* */

drag('#drag1',{container:document.documentElement});  //拖动#drag1,定位left值最小为0。
drag('#drag2',{container:'null'});                    //拖动#drag2,定位left值则可能为负数。

targetContainer

{element|string} 元素节点或选择器。

匹配拖动元素的容器。

例如: drag('div',{targetContainer:'#container'}),相当于 drag('#container div');

handler

{element|string} 元素节点或选择器

触发拖动的元素,默认点击当前元素任意位置触发拖动。

proxy

{bool}

是否开启拖动代理效果。

默认直接改变目标元素的定位,如果proxy为true,则直到拖动完成后,才改变目标元素的定位,拖动过程中,实际拖动的是一个占位浮层。

posProperty

{array}

指定定位的样式属性。默认通过改变元素的left和top值进行定位。

通过传入 {posProperty:[ 'right', 'bottom' ]},则使用 right和bottom进行定位。

posProperty只识别"left","right", "top", "bottom"

检测当存在"right"时,则使用right,否则使用left。当存在"bottom"时,则使用bottom,否则使用top。

event.dragActive

function(dragElement,startOffset)

触发拖动元素时触发,dragElement 为当前拖动元素,startOffset 为当前拖动元素的坐标。

note: 该事件实际是在mousedown事件中触发。

event.dragStart

function(dragElement,startOffSet)

开始拖动时触发,该事件回调如果返回布尔型的false,则取消拖动。例如:

drag('.drag', {
    event: {
        dragStart: function () {
            return window.unlock == false;
        }
    }
})

dragElement 为当前拖动元素,startOffset 为当前拖动元素的坐标。

note: 该事件实际是在首次执行mousemove事件时触发。

event.dragMove

function(dragElement,startOffset,endOffset)

拖动过程中触发的事件。

dragElement 为当前拖动元素,startOffset 为拖动元素拖动开始时的坐标。endOffset 为拖动元素的当前坐标。

note: 该事件实际是在mousemove事件中触发。

event.dragEnd

function(dragElement,startOffset,endOffset)

拖动结束事件。

dragElement 为当前拖动元素,startOffset 为拖动元素拖动开始时的坐标。endOffset 为拖动元素的当前坐标。

note:该事件实际是在mouseup事件中触发。

建议

在拖动过程中,可能会出现选中情况。这种情况并没有在组件中做处理,如有需要,建议开发者在dragStartdragActive事件中做处理。