jQuery实现拖拽功能 模块拖拽
来源: 阅读:2576 次 日期:2015-04-17 13:41:49
温馨提示: 小编为您整理了“jQuery实现拖拽功能 模块拖拽”,方便广大网友查阅!

jQuery实现拖拽功能 模块拖拽,基于jQuery的拖拽插件,能够方便的在Web上实现拖拽功能,同时支持拖拽动作结束之后的的回调方法自己定义。

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">

<script type="text/javascript" src="js/jquery-1.8.1.min.js"></script>

<script type="text/javascript" src="js/jquery.jsmartdrag.js"></script>

<link href="css/jsmartdrag.css" rel="stylesheet" type="text/css" />

<title>jsmartdrag实例页面</title>

<script type="text/javascript">

$(document).ready(function(){

js = $(".source").jsmartdrag({

target:'.target',

afterDrag:afterDrag

});

});

function afterDrag(selected,currentObj,targetSelected){

if(selected){

alert("将元素ID为"+currentObj.attr("id")+"移动到了元素ID为"+targetSelected.attr("id")+"上");

}else{

alert("没有拖动到指定的区域里哦!");

}

}

</script>

</head>

<body>

<div id="target1" class="target">target1</div>

<div id="target2" class="target">target2</div>

<div id="target3" class="target">target3</div>

<div id="source1" class="source" >source1</div>

<div id="source2" class="source" >source2</div>

<div id="source3" class="source" >source3</div>

</body>

</html>

jquery.jsmartdrag.js

(function($){

var move = false;

var cloneDiv = null;

var targetObj = null;

var currentObj = null;

var targetSelected = null;

var selected = false;

var scrollTop = 0;

$.fn.jsmartdrag = function(options){

var jQueryObj = this;

var defaults = {

sourceClass:"jsmartdrag-source",

sourceHoverClass:"jsmartdrag-source-hover",

cursorHoverClass:"jsmartdrag-cursor-hover",

targetHoverClass:"jsmartdrag-target-hover",

canSelect:false,

target:".target",

onDrag: function(){},

afterDrag: function(selected,currentObj,targetObj){}

};

options = $.extend(defaults, options);

this.each(function(){

$("body").css("-moz-user-select","none");

if(!defaults.canSeletct){

document.ondragstart = function () { return false; }; //禁止浏览器的拖拽行为

document.onselectstart = function () {return false; };//禁止浏览器的选中行为

}

if(options.target!=null){

targetObj = $(options.target);

}

$(this).addClass(options.sourceClass);

$(this).mousedown(function(){

currentObj = $(this);

move = true;

$(this).addClass(options.sourceHoverClass);

cloneDiv = $(this).clone();

cloneDiv.attr("id","cloneDiv");

cloneDiv.addClass(options.sourceHoverClass);

scrollTop = $("html,body").scrollTop();//当鼠标点击的时候才计算滚动的高度,是为了防止页面浏览的时候用户改变了浏览器高度

});

$(document).mousemove(function(event){

if(move){

if($("#cloneDiv").length<=0){

$("body").append(cloneDiv);

}

var dragPos = {x1:0,x2:0,y1:0,y2:0};

var pageX = 0;

var pageY = 0;

if($.browser.msie){

pageX = event.clientX;

pageY = event.clientY+scrollTop;

}else{

pageX = event.pageX;

pageY = event.pageY;

}

dragPos.x1 =pageX-cloneDiv.innerWidth()/2;

dragPos.y1 = pageY-cloneDiv.innerHeight()/2;

cloneDiv.css({left:dragPos.x1+"px",top:dragPos.y1+"px",position:'absolute'});

if(targetObj.length>0){

targetObj.each(function(){

if(checkAreaOverride(cloneDiv,$(this))){

$(this).addClass(options.targetHoverClass);

}else{

$(this).removeClass(options.targetHoverClass);

}

});

}

options.onDrag();

}

});

$(document).mouseup(function(){

if(move){

move = false;

if(cloneDiv!=null && targetObj!=null){

if($($("[class$='jsmartdrag-target-hover']")[0]).length>0){

targetSelected = $($("[class$='jsmartdrag-target-hover']")[0]);

selected = true;

}

options.afterDrag(selected,currentObj,targetSelected);

//恢复初始状态

cloneDiv.remove();

cloneDiv.removeClass(options.cursorHoverClass);

$("[class$='jsmartdrag-target-hover']").each(function(){

$(this).removeClass(options.targetHoverClass);

});

currentObj.removeClass(options.sourceHoverClass);

currentObj = null;

if(selected == true){

targetSelected.removeClass(options.targetHoverClass);

targetSelected = null;

selected = false;

}

}

}

});

});

function checkAreaOverride (_cloneDiv,_targetObj){

//这里来判断是否在里面哦!

var source_left = _cloneDiv.offset().left;

var source_top = _cloneDiv.offset().top;

var source_right = _cloneDiv.offset().left+cloneDiv.innerWidth();

var source_bottom = _cloneDiv.offset().top+cloneDiv.innerHeight();

var target_left = _targetObj.offset().left;

var target_top = _targetObj.offset().top;

var target_right = _targetObj.offset().left+targetObj.innerWidth();

var target_bottom = _targetObj.offset().top+targetObj.innerHeight();

var new_area_left = max(source_left,target_left);

var new_area_top = max(source_top,target_top);

var new_area_right = min(source_right,source_right);

var new_area_bottom = min(source_bottom,target_bottom);

if(new_area_left<target_right&&new_area_top<target_bottom&&new_area_right>target_left&&new_area_bottom>target_top){

$("[class$='jsmartdrag-target-hover']").each(function(){

$(this).removeClass("jsmartdrag-target-hover");

});

return true;

}else{

return false;

}

}

function max(_p1,_p2){

if(_p1>_p2){

return _p1;

}else{

return _p2;

}

}

function min(_p1,_p2){

if(_p1>_p2){

return _p2;

}else{

return _p1;

}

}

return jQueryObj;

};

})(jQuery);

更多信息请查看IT技术专栏

更多信息请查看脚本栏目
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们 | 联系我们 | 人才招聘 | 网站声明 | 网站帮助 | 非正式的简要咨询 | 简要咨询须知 | 加入群交流 | 手机站点 | 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:hfpxwx
咨询QQ:526150442(9:00—18:00)版权所有:
云南网警报警专用图标
Baidu
map