教程集 www.jiaochengji.com
教程集 >  jQuery  >  jquery 教程  >  正文 基于jquery的jqDnR拖拽溢出的修改

基于jquery的jqDnR拖拽溢出的修改

发布时间:2013-07-15   编辑:jiaochengji.com
fix bug:溢出之后不能回来的,添加在范围内移动,需要的朋友可以参考下。
fix bug:溢出之后不能回来的,添加在范围内移动,需要的朋友可以参考下。
复制代码 代码如下:

/*
* jqDnR - Minimalistic Drag'n'Resize for jquery.
*
* Copyright (c) 2007 Brice Burgess <bhb@iceburg.net>, http://www.iceburg.net/
* Licensed under the MIT License:
* http://www.opensource.org/licenses/mit-license.php
*
* $Version: 2007.08.19 +r2
* last modified by leegle 2011.02.11
* fix bug:溢出之后不能回来的,添加在范围内移动
*/
(function($) {
$.fn.jqDrag = function(h) { return i(this, h, 'd'); };
$.fn.jqResize = function(h) { return i(this, h, 'r'); };
$.jqDnR = { dnr: {}, e: 0,
drag: function(v) {
if (M.k == 'd') {
//修改的位置 李飞二〇一一年二月十一日 14:35:19
E.css({ left: (M.X + v.pageX - M.pX)<0? 0:(M.X + v.pageX - M.pX)<document.documentElement.clientWidth- M.W?(M.X + v.pageX - M.pX):document.documentElement.clientWidth- M.W, top: (M.Y + v.pageY - M.pY)<0?0:(M.Y + v.pageY - M.pY)<document.documentElement.clientHeight -M.H ?(M.Y + v.pageY - M.pY): document.documentElement.clientHeight- M.H });
}
else {E.css({ width: Math.max(v.pageX - M.pX + M.W, 0), height: Math.max(v.pageY - M.pY + M.H, 0) }); return false;}
},
stop: function() { E.css('opacity', M.o); $(document).unbind('mousemove', J.drag).unbind('mouseup', J.stop); }
};
var J = $.jqDnR, M = J.dnr, E = J.e,
i = function(e, h, k) {
return e.each(function() {
h = (h) ? $(h, e) : e;
h.bind('mousedown', { e: e, k: k }, function(v) {
var d = v.data, p = {}; E = d.e;
// attempt utilization of dimensions plugin to fix IE issues
if (E.css('position') != 'relative') {
p = E.position();
if (!($.browser.msie && ($.browser.version == "6.0")) && (E.css('position') == 'fixed')) {
p.top -= $(window).scrollTop(); p.left -= $(window).scrollLeft()
}
}
M = { X: p.left || f('left') || 0, Y: p.top || f('top') || 0, W: f('width') || E[0].scrollWidth || 0, H: f('height') || E[0].scrollHeight || 0, pX: v.pageX, pY: v.pageY, k: d.k, o: E.css('opacity') };
E.css({ opacity: 0.8 }); $(document).mousemove($.jqDnR.drag).mouseup($.jqDnR.stop);
return false;
});
});
},
f = function(k) { return parseInt(E.css(k)) || false; };
})(jQuery);

您可能感兴趣的文章:
基于jquery的jqDnR拖拽溢出的修改
jQuery拖拽插件 jqDnR
JQuery之拖拽插件实现代码
HTML5实现拖拽批量上传文件的代码
JQuery Dialog(JS 模态窗口,可拖拽的DIV)
JQUBar 基于JQUERY的柱状图插件
HTML5 DragEvent接口的实例讲解
jquery1.4后 jqDrag 拖动 不可用
jquery实现简单的拖拽效果实例兼容所有主流浏览器(优化篇)
JQuery拖拽元素改变大小尺寸实现代码

[关闭]
~ ~