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();
}
};
}
}
}
分享到:
相关推荐
7. **可拖动元素标识**:为了让JavaScript知道哪些元素可以被拖动,可以添加一个特定的CSS类或者数据属性到可拖动元素上,然后在JavaScript中根据这个标识来处理拖拽逻辑。 在实际开发中,为了使代码更简洁和易于...
在JavaScript编程中,实现窗口拖动效果是一项常见的需求,尤其在网页交互设计中。这个话题主要涉及以下几个核心知识点: 1. **DOM操作**:在JavaScript中,我们需要通过DOM(Document Object Model)来选取和操作...
而jQuery库是JavaScript的一个强大工具,它简化了DOM操作、事件处理、动画制作以及Ajax交互等任务,使得开发者能更高效地工作。今天我们将讨论一个基于jQuery的插件——"swing",它为卡片元素提供了独特的拖拽功能,...
**jQuery UI工具类详解** jQuery UI 是一个基于 jQuery JavaScript 库的用户界面插件集合,它提供了一系列丰富且可自定义的组件,适用于构建交互式、功能强大的网页应用。这款插件深受开发者喜爱,无论你是前端新手...
JavaScript 自由拖拽类是一种...总之,JavaScript 自由拖拽类是前端开发中增强用户交互的重要工具,通过解析和理解 `dragdrop_0.5.js` 的源码,我们可以学习如何构建自己的拖放功能,并根据实际需求进行定制和优化。
"强大的js拖动控件"标题所提及的,可能是一个高效的JavaScript库或者插件,用于实现这种交互效果。在实际应用中,这种控件可以用于文件管理器、桌面应用模拟、图表元素调整等场景。 描述中的“博文链接:...
JavaScript(简称JS)是一种广泛用于网页和网络应用的编程语言,尤其在客户端渲染和交互方面发挥着重要作用。本文将深入探讨使用JS进行图形绘制的方法,包括VML和SVG两种技术,以及如何创建一个简单的画图工具。 ...
本示例中的“jquery div容器拖拽放大缩小浮动层代码”是一个利用jQuery实现的功能,允许用户对div元素进行拖动、缩放以及使其在页面上浮动。下面将详细介绍这一功能的实现原理和相关知识点。 1. **jQuery选择器**:...
JavaScript.as ---------------------- javascript交互 HTTPS.as ---------------------- url随机数 SNS.as ---------------------- 各个sns网站的分享 timeline: prevPlay.as ---------------------...
而“工具”可能指的是这个dbx项目提供了一些工具类或函数,简化了开发过程。 在“puzzle”这个文件名中,可能暗示了这个项目包含一些解谜或挑战性的部分,需要我们去研究和拼凑,以完全掌握JavaScript拖拽效果的...
而"工具"标签可能意味着这个可拖动的div可以作为一个实用的小工具,比如对话框、提示框或者自定义的交互元素。 在提供的压缩包文件列表中,"sasd.html"可能是实现这一功能的一个实例文件。它可能包含了上述代码的...
在拖拽排序的过程中,`jquery.dad.js`首先会为每个可拖动的`div`元素添加必要的CSS类和数据属性,以便识别和管理它们。`jquery.dad.css`文件则提供了这些元素的样式规则,确保在拖动过程中视觉效果的平滑过渡。例如...
通过类`.container`、`.container-fluid`定义容器,再利用`.row`类来组织行,并在行内嵌套`.col-*-*`类的列,可以轻松创建多列布局。例如,创建两列等宽布局,可以写成: ```html 第一列内容 第二列内容 ``...
在微信小程序开发中,工具类库的创建与应用是一个重要的环节,它可以帮助开发者更高效地构建用户界面,处理数据和实现复杂功能。本案例聚焦于图表的实现,提供了丰富的源码示例,帮助开发者理解如何在微信小程序中...
学习如何使用预定义的CSS类来布局和美化图表容器。 2. **图表库集成**:选择一个适合的图表库,如Highcharts,它是一个功能丰富的JavaScript图表库,支持各种图表类型(如柱状图、折线图、饼图等)并具有高度自定义...
根据给定的信息,本文将详细解释如何使用JavaScript来实现元素的上下左右拖动功能,并对相关的代码进行解读。 ### 一、实现上下左右拖动的基本原理 在网页中实现元素的拖动通常涉及到两个主要步骤:一是响应用户的...
在实现这一功能时,开发者可能使用了Ext.util.Draggable类,这是Ext JS提供的一种用于创建可拖动对象的工具。通常,会通过创建一个新的实例,并配置相应的参数,如拖动范围、回调函数等,来使元素具备拖动行为。同时...
在给定的标题“jquery拖拽排序插件div自由拖动排序代码”中,我们主要讨论的是如何利用jQuery实现一个功能,让用户能够自由地通过拖放操作来对页面上的div元素进行排序。这种功能在许多应用场景中都非常实用,比如...
在网页开发中,图片缩放功能常常被用于增强用户体验,...同时,Hammer.js的轻量级和高效性能使其成为实现这类功能的理想选择。通过深入理解和灵活运用这些工具,开发者可以创造出更生动、更具吸引力的网页应用程序。
通常会有一个容器元素包含两个或更多部分,每个部分都有自己的CSS类以区分和控制它们的初始位置。 五、CSS样式 CSS文件(可能在`js`目录下)用于定义验证码元素的布局和样式,包括大小、位置、边框和过渡效果。...