`
tianqinghua
  • 浏览: 27760 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类

JS拖动容器工具类

阅读更多
var isIE = (document.all) ? true : false;
var $ = function(id) {
	return "string" == typeof id ? document.getElementById(id) : id;
};
var Class = {
	create : function() {
		return function() {
			this.initialize.apply(this, arguments);
		}
	}
}
var Extend = function(destination, source) {
	for (var property in source) {
		destination[property] = source[property];
	}
}
var Bind = function(object, fun) {
	return function() {
		return fun.apply(object, arguments);
	}
}
var BindAsEventListener = function(object, fun) {
	var args = Array.prototype.slice.call(arguments).slice(2);
	return function(event) {
		return fun.apply(object, [event || window.event].concat(args));
	}
}
var CurrentStyle = function(element) {
	return element.currentStyle
			|| document.defaultView.getComputedStyle(element, null);
}
function addEventHandler(oTarget, sEventType, fnHandler) {
	if (oTarget.addEventListener) {
		oTarget.addEventListener(sEventType, fnHandler, false);
	} else if (oTarget.attachEvent) {
		oTarget.attachEvent("on" + sEventType, fnHandler);
	} else {
		oTarget["on" + sEventType] = fnHandler;
	}
};
function removeEventHandler(oTarget, sEventType, fnHandler) {
	if (oTarget.removeEventListener) {
		oTarget.removeEventListener(sEventType, fnHandler, false);
	} else if (oTarget.detachEvent) {
		oTarget.detachEvent("on" + sEventType, fnHandler);
	} else {
		oTarget["on" + sEventType] = null;
	}
}; // 拖放程序
var Drag = Class.create();
Drag.prototype = { // 拖放对象
	initialize : function(drag, options) {
		this.Drag = $(drag);// 拖放对象
		this._x = this._y = 0;// 记录鼠标相对拖放对象的位置
		this._marginLeft = this._marginTop = 0;// 记录margin //事件对象(用于绑定移除事件)
		this._fM = BindAsEventListener(this, this.Move);
		this._fS = Bind(this, this.Stop);
		this.SetOptions(options);
		this.Limit = !!this.options.Limit;
		this.mxLeft = parseInt(this.options.mxLeft);
		this.mxRight = parseInt(this.options.mxRight);
		this.mxTop = parseInt(this.options.mxTop);
		this.mxBottom = parseInt(this.options.mxBottom);
		this.LockX = !!this.options.LockX;
		this.LockY = !!this.options.LockY;
		this.Lock = !!this.options.Lock;
		this.onStart = this.options.onStart;
		this.onMove = this.options.onMove;
		this.onStop = this.options.onStop;
		this._Handle = $(this.options.Handle) || this.Drag;
		this._mxContainer = $(this.options.mxContainer) || null; // setZB("bgDiv","div");
		this.Drag.style.position = "absolute"; // 透明
		if (isIE && !!this.options.Transparent) { // 填充拖放对象
			with (this._Handle.appendChild(document.createElement("div")).style) {
				width = height = "100%";
				backgroundColor = "#fff";
				filter = "alpha(opacity:0)";
			}
		} // 修正范围
		this.Repair();
		addEventHandler(this._Handle, "mousedown", BindAsEventListener(this,
				this.Start));
	}, // 设置默认属性
	SetOptions : function(options) {
		this.options = {// 默认值
			Handle : "",// 设置触发对象(不设置则使用拖放对象)
			Limit : false,// 是否设置范围限制(为true时下面参数有用,可以是负数)
			mxLeft : 0,// 左边限制
			mxRight : 9999,// 右边限制
			mxTop : 0,// 上边限制
			mxBottom : 9999,// 下边限制
			mxContainer : "",// 指定限制在容器内
			LockX : false,// 是否锁定水平方向拖放
			LockY : false,// 是否锁定垂直方向拖放
			Lock : false,// 是否锁定
			Transparent : false,// 是否透明
			onStart : function() {
			},// 开始移动时执行
			onMove : function() {
			},// 移动时执行
			onStop : function() {
			}// 结束移动时执行
		};
		Extend(this.options, options || {});
	}, // 准备拖动
	Start : function(oEvent) {
		if (this.Lock) {
			return;
		}
		this.Repair(); // 记录鼠标相对拖放对象的位置
		this._x = oEvent.clientX - this.Drag.offsetLeft;
		this._y = oEvent.clientY - this.Drag.offsetTop; // 记录margin
		this._marginLeft = parseInt(CurrentStyle(this.Drag).marginLeft) || 0;
		this._marginTop = parseInt(CurrentStyle(this.Drag).marginTop) || 0; // mousemove时移动
		// mouseup时停止
		addEventHandler(document, "mousemove", this._fM);
		addEventHandler(document, "mouseup", this._fS);
		if (isIE) { // 焦点丢失
			addEventHandler(this._Handle, "losecapture", this._fS); // 设置鼠标捕获
			this._Handle.setCapture();
		} else { // 焦点丢失
			addEventHandler(window, "blur", this._fS); // 阻止默认动作
			oEvent.preventDefault();
		}; // 附加程序
		this.onStart();
	}, // 修正范围
	Repair : function() {
		if (this.Limit) { // 修正错误范围参数
			this.mxRight = Math.max(this.mxRight, this.mxLeft
					+ this.Drag.offsetWidth);
			this.mxBottom = Math.max(this.mxBottom, this.mxTop
					+ this.Drag.offsetHeight); // 如果有容器必须设置position为relative来相对定位,并在获取offset之前设置
			!this._mxContainer
					|| CurrentStyle(this._mxContainer).position == "relative"
					|| (this._mxContainer.style.position = "relative");
		}
	}, // 拖动
	Move : function(oEvent) { // 判断是否锁定
		if (this.Lock) {
			this.Stop();
			return;
		}; // 清除选择
		window.getSelection
				? window.getSelection().removeAllRanges()
				: document.selection.empty(); // 设置移动参数
		var iLeft = oEvent.clientX - this._x, iTop = oEvent.clientY - this._y; // 设置范围限制
		if (this.Limit) { // 设置范围参数
			var mxLeft = this.mxLeft, mxRight = this.mxRight, mxTop = this.mxTop, mxBottom = this.mxBottom; // 如果设置了容器,再修正范围参数margin
			if (!!this._mxContainer) {
				mxLeft = Math.max(mxLeft, 0);
				mxTop = Math.max(mxTop, 0);
				mxRight = Math.min(mxRight, this._mxContainer.clientWidth);
				mxBottom = Math.min(mxBottom, this._mxContainer.clientHeight);
			}; // 修正移动参数
			iLeft = Math.max(Math.min(iLeft, mxRight - this.Drag.offsetWidth),
					mxLeft);
			iTop = Math.max(Math.min(iTop, mxBottom - this.Drag.offsetHeight),
					mxTop);
		} // 设置位置,并修正
		if (!this.LockX) {
			this.Drag.style.left = iLeft - this._marginLeft + "px";
		}
		if (!this.LockY) {
			this.Drag.style.top = iTop - this._marginTop + "px";
		} // 附加程序
		this.onMove();
	}, // 停止拖动
	Stop : function() { // 移除事件
		removeEventHandler(document, "mousemove", this._fM);
		removeEventHandler(document, "mouseup", this._fS);
		if (isIE) {
			removeEventHandler(this._Handle, "losecapture", this._fS);
			this._Handle.releaseCapture();
		} else {
			removeEventHandler(window, "blur", this._fS);
		}; // 附加程序
		this.onStop();
	}
};
}
	}
}
 
分享到:
评论

相关推荐

    js 仿 igoogle 拖拽 效果

    7. **可拖动元素标识**:为了让JavaScript知道哪些元素可以被拖动,可以添加一个特定的CSS类或者数据属性到可拖动元素上,然后在JavaScript中根据这个标识来处理拖拽逻辑。 在实际开发中,为了使代码更简洁和易于...

    js窗口拖动效果

    在JavaScript编程中,实现窗口拖动效果是一项常见的需求,尤其在网页交互设计中。这个话题主要涉及以下几个核心知识点: 1. **DOM操作**:在JavaScript中,我们需要通过DOM(Document Object Model)来选取和操作...

    带弹性摇摆效果的卡片js拖拽插件swing

    而jQuery库是JavaScript的一个强大工具,它简化了DOM操作、事件处理、动画制作以及Ajax交互等任务,使得开发者能更高效地工作。今天我们将讨论一个基于jQuery的插件——"swing",它为卡片元素提供了独特的拖拽功能,...

    jquery-ui工具类

    **jQuery UI工具类详解** jQuery UI 是一个基于 jQuery JavaScript 库的用户界面插件集合,它提供了一系列丰富且可自定义的组件,适用于构建交互式、功能强大的网页应用。这款插件深受开发者喜爱,无论你是前端新手...

    Javascript自由拖拽类

    JavaScript 自由拖拽类是一种...总之,JavaScript 自由拖拽类是前端开发中增强用户交互的重要工具,通过解析和理解 `dragdrop_0.5.js` 的源码,我们可以学习如何构建自己的拖放功能,并根据实际需求进行定制和优化。

    强大的js拖动控件

    "强大的js拖动控件"标题所提及的,可能是一个高效的JavaScript库或者插件,用于实现这种交互效果。在实际应用中,这种控件可以用于文件管理器、桌面应用模拟、图表元素调整等场景。 描述中的“博文链接:...

    js画图工具

    JavaScript(简称JS)是一种广泛用于网页和网络应用的编程语言,尤其在客户端渲染和交互方面发挥着重要作用。本文将深入探讨使用JS进行图形绘制的方法,包括VML和SVG两种技术,以及如何创建一个简单的画图工具。 ...

    jquery div容器拖拽放大缩小浮动层代码

    本示例中的“jquery div容器拖拽放大缩小浮动层代码”是一个利用jQuery实现的功能,允许用户对div元素进行拖动、缩放以及使其在页面上浮动。下面将详细介绍这一功能的实现原理和相关知识点。 1. **jQuery选择器**:...

    as3比较详尽的工具类

    JavaScript.as ---------------------- javascript交互 HTTPS.as ---------------------- url随机数 SNS.as ---------------------- 各个sns网站的分享 timeline: prevPlay.as ---------------------...

    完美的JavaScript拖拽效果-dbx

    而“工具”可能指的是这个dbx项目提供了一些工具类或函数,简化了开发过程。 在“puzzle”这个文件名中,可能暗示了这个项目包含一些解谜或挑战性的部分,需要我们去研究和拼凑,以完全掌握JavaScript拖拽效果的...

    js弹出可拖动div

    而"工具"标签可能意味着这个可拖动的div可以作为一个实用的小工具,比如对话框、提示框或者自定义的交互元素。 在提供的压缩包文件列表中,"sasd.html"可能是实现这一功能的一个实例文件。它可能包含了上述代码的...

    jquery.dad.js div拖拽排序,及bug优化

    在拖拽排序的过程中,`jquery.dad.js`首先会为每个可拖动的`div`元素添加必要的CSS类和数据属性,以便识别和管理它们。`jquery.dad.css`文件则提供了这些元素的样式规则,确保在拖动过程中视觉效果的平滑过渡。例如...

    bootstrap布局可视化可拖拽

    通过类`.container`、`.container-fluid`定义容器,再利用`.row`类来组织行,并在行内嵌套`.col-*-*`类的列,可以轻松创建多列布局。例如,创建两列等宽布局,可以写成: ```html 第一列内容 第二列内容 ``...

    微信小程序开发-工具类-图表案例源码.zip

    在微信小程序开发中,工具类库的创建与应用是一个重要的环节,它可以帮助开发者更高效地构建用户界面,处理数据和实现复杂功能。本案例聚焦于图表的实现,提供了丰富的源码示例,帮助开发者理解如何在微信小程序中...

    Bootstrap图表拖拽

    学习如何使用预定义的CSS类来布局和美化图表容器。 2. **图表库集成**:选择一个适合的图表库,如Highcharts,它是一个功能丰富的JavaScript图表库,支持各种图表类型(如柱状图、折线图、饼图等)并具有高度自定义...

    js上下拖动

    根据给定的信息,本文将详细解释如何使用JavaScript来实现元素的上下左右拖动功能,并对相关的代码进行解读。 ### 一、实现上下左右拖动的基本原理 在网页中实现元素的拖动通常涉及到两个主要步骤:一是响应用户的...

    Ext div拖动demo

    在实现这一功能时,开发者可能使用了Ext.util.Draggable类,这是Ext JS提供的一种用于创建可拖动对象的工具。通常,会通过创建一个新的实例,并配置相应的参数,如拖动范围、回调函数等,来使元素具备拖动行为。同时...

    jquery拖拽排序插件div自由拖动排序代码

    在给定的标题“jquery拖拽排序插件div自由拖动排序代码”中,我们主要讨论的是如何利用jQuery实现一个功能,让用户能够自由地通过拖放操作来对页面上的div元素进行排序。这种功能在许多应用场景中都非常实用,比如...

    图片缩放JS插件

    在网页开发中,图片缩放功能常常被用于增强用户体验,...同时,Hammer.js的轻量级和高效性能使其成为实现这类功能的理想选择。通过深入理解和灵活运用这些工具,开发者可以创造出更生动、更具吸引力的网页应用程序。

    jQuery移动端拖拽式补缺验证码插件.rar

    通常会有一个容器元素包含两个或更多部分,每个部分都有自己的CSS类以区分和控制它们的初始位置。 五、CSS样式 CSS文件(可能在`js`目录下)用于定义验证码元素的布局和样式,包括大小、位置、边框和过渡效果。...

Global site tag (gtag.js) - Google Analytics