实现javascript随意定制拖动功能,jQueryUI有一个简单的拖动效果,其演示页面[查看jQueryUI Draggable演示],但实现的拖动展示效果非常有限,这里介绍一个jQuery插件$.event.special.drag拖动。演示效果可在线查看[查看演示效果]
下载$.event.special.drag拖动插件

javascript代码分析
一,实现随意拖动效果,点击按钮可停止拖动
- $('#demo1_box')
- .bind('drag',function( event ){
- $( this ).css({
- top: event.offsetY,
- left: event.offsetX
- });
- });
其中event.offsetY与event.offsetX分别表示可拖动的左上角坐标,这里表示可随意拖动。
二,沿X坐标或Y坐标拖动,默认沿X坐标拖动,如果按SHIFT键则沿Y坐标拖动
- $('#demo2_box')
- .bind('drag',function( event ){
- $( this ).css( event.shiftKey ? {
- top: event.offsetY } : {
- left: event.offsetX
- });
- });
使用三元操作符event.shiftKey ? {top: event.offsetY } : {left: event.offsetX },如果按SHIFT键,则沿event.offsetY拖动,否则沿 event.offsetX拖动.
三,按每格20px方式拖动
- $('#demo3_box')
- .bind('drag',function( event ){
- $( this ).css({
- top: Math.round( event.offsetY/20 ) * 20,
- left: Math.round( event.offsetX/20 ) * 20
- });
- });
计算方法Math.round( event.offsetY/20 ) * 20和Math.round( event.offsetX/20 ) * 20
四,实现以手柄层可拖动效果
$('#demo4_box')
.bind('dragstart',function( event ){
return $(event.target).is('.handle');
})
.bind('drag',function( event ){
$( this ).css({
top: event.offsetY,
left: event.offsetX
});
});
dragstart表示拖动开始,event.target表示当前事件目标,当指向类名为.handle时触发拖动。
五,实现以手柄层可拖动,并增加拖动层显示样式效果
- $('#demo5_box')
- .bind('dragstart',function( event ){
- if ( !$(event.target).is('.handle') ) return false;
- $( this ).addClass('active');
- })
- .bind('drag',function( event ){
- $( this ).css({
- top: event.offsetY,
- left: event.offsetX
- });
- })
- .bind('dragend',function( event ){
- $( this ).removeClass('active');
- });
dragend表示当拖动结束后触发的方法
六,代理拖动效果,当拖动时只拖动一个代理层,然后再显示拖动结果
$('#demo6_box')
.bind('dragstart',function( event ){
if ( !$(event.target).is('.handle') ) return false;
return $( this ).css('opacity',.5)
.clone().addClass('active')
.insertAfter( this );
})
.bind('drag',function( event ){
$( event.dragProxy ).css({
top: event.offsetY,
left: event.offsetX
});
})
.bind('dragend',function( event ){
$( event.dragProxy ).remove();
$( this ).animate({
top: event.offsetY,
left: event.offsetX,
opacity: 1
})
});
opacity表示代理拖动层的透明度
七,在圆圈内拖动
- $('#demo7_box')
- .bind('dragstart',function( event ){
- var data = $( this ).data('dragcircle');
- if ( data ) data.$circle.show();
- else {
- data = {
- radius: 200, $circle: $([]),
- halfHeight: $( this ).outerHeight()/2,
- halfWidth: $( this ).outerWidth()/2
- };
- data.centerX = event.offsetX + data.radius + data.halfWidth,
- data.centerY = event.offsetY + data.halfHeight,
- // create divs to highlight the path...
- $.each( new Array(72), function( i, a ){
- angle = Math.PI * ( ( i-36 ) / 36 );
- data.$circle = data.$circle.add(
- $('<div class="point" />').css({
- top: data.centerY + Math.cos( angle )*data.radius,
- left: data.centerX + Math.sin( angle )*data.radius,
- })
- );
- });
- $( this ).after( data.$circle ).data('dragcircle', data );
- }
- })
- .bind('drag',function( event ){
- var data = $( this ).data('dragcircle'),
- angle = Math.atan2( event.pageX - data.centerX, event.pageY - data.centerY );
- $( this ).css({
- top: data.centerY + Math.cos( angle )*data.radius - data.halfHeight,
- left: data.centerX + Math.sin( angle )*data.radius - data.halfWidth
- });
- })
- .bind('dragend',function(){
- $( this ).data('dragcircle').$circle.hide();
- });
拖动开始生成一个圆周,拖动结束后隐藏圆圈,这里可以了解一个jQuery如何生成一个圆圈。
实现定制拖动效果,这里展示了jQuery插件$.event.special.drag的七种拖动效果,可扩展拖动功能,与简单的jQueryUI Draggable拖动相比,功能更为强大,值得推荐。