问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

js/jquery 操作div 移动

发布网友 发布时间:2022-04-07 05:41

我来回答

1个回答

热心网友 时间:2022-04-07 07:10

正好我最近 在搞 JQUERY 所以改写了个插件
调用:$(".x-movable").Drags({handler:".x-panel-header",zIndex:10000,opacity:0.7,direction:"x"});
你可以参考一下,以下是代插件码:

(function($) {
$.extend($.fn, {
getCss: function(key) {
var v = parseInt(this.css(key));
if (isNaN(v))
return false;
return v;
}
});
$.fn.Drags = function(opts) {
var obg=$(this)
var ps = $.extend({
zIndex: 20,
opacity: .7,
handler: null,
onMove: function() { },
onDrop: function() { }
}, opts);
var dragndrop = {
drag: function(e) {
var dragData = e.data.dragData;
dragData.target.css({
left:(ps.direction=="y")?(dragData.left):(dragData.left + e.pageX - dragData.offLeft),
top: (ps.direction=="x")?(dragData.top):(dragData.top + e.pageY - dragData.offTop)
});
dragData.onMove(e);
},
drop: function(e) {

var dragData = e.data.dragData;
dragData.target.css(dragData.oldCss);
dragData.onDrop(e);
$().unbind('mousemove', dragndrop.drag)
.unbind('mouseup', dragndrop.drop);
}
}
return this.each(function() {
var me = this;
var handler = null;
if (typeof ps.handler == 'undefined' || ps.handler == null){
handler = $(me);
}else{
handler = (typeof ps.handler == 'string' ? $(ps.handler, this) : ps.handle);
}
handler.bind('mousedown', { e: me }, function(s) {
var target = $(s.data.e);
var oldCss = {};
if (target.css('position') != 'absolute') {
try {
target.position(oldCss);
} catch (ex) { }
target.css('position', 'absolute');
}
oldCss.opacity = target.getCss('opacity') || 1;
var dragData = { //初始数据
left: oldCss.left || target.getCss('left') || 0,
top: oldCss.top || target.getCss('top') || 0,
width: target.width() || target.getCss('width'),
height: target.height() || target.getCss('height'),
offLeft: s.pageX,
offTop: s.pageY,
oldCss: oldCss,
onMove: ps.onMove,
onDrop: ps.onDrop,
handler: handler,
target: target
}
target.css('opacity', ps.opacity);
$().bind('mousemove', { dragData: dragData }, dragndrop.drag)
.bind('mouseup', { dragData: dragData }, dragndrop.drop);
});
});
}
})(jQuery);

调用说明:$(".x-movable").Drags({handler:".x-panel-header",zIndex:10000,opacity:0.7,direction:"x"});

其中$(".x-movable")是要被移动的DIV,".x-panel-header"是拖动手柄,科省略。 direction是移动方向,有"x"和"y"两个参数。

下面是我实际运用中更复杂的例子:
$(".x-layout-split-west").Drags({
zIndex:10000,
opacity:0.7,
direction:"x",
onDrop:function(e){
$(".x-layout-split-west").removeClass("x-splitbar-proxy")
var l=parseInt(e.data.dragData.target.css("left"))
if (l<ps.wmin){l=ps.wmin;}
if (l>ps.wmax){l=ps.wmax;}
ps.ww=l
ps.cl=l+ps.margins
ps.cw=w-ps.ew-ps.cl-ps.margins
$("#west").css({width:ps.ww});
//$("#west").css({left:l});
//$("#center .x-panel-body").css({width:ps.ch});
$("#center").css({width:ps.cw,left:ps.cl});
$(".x-layout-split-west").css("left",l)
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
怀孕错过了糖筛怎么办 糖筛有哪些注意事项 怀孕几个月查唐筛 蔡家沟镇慈云寺 哈佳高铁高楞站多少平方米位置在那 超威电池生产日期怎么看 超威电池寿命一般多长时间 华晨宇鸟巢四面台10w+秒罄!!火星演唱会舞台概念图震撼发布! 手机连接160wifi电脑蓝屏使用160WiFi遇到问题应该如何解决 为什么手机wifi总是刚开启,锁屏就掉了。wifi设置里的休眠模式也是永久的... 建行卡为什么不能网上转账 学校发我们的建设银行卡一定要激活吗? 我打电话查余额说输入取钱密码... 烫伤后,水泡挑破了,现在该如何做? 怎么退出小说模式 我在手机上登小说阅读网的账号,可是怎么退掉啊,退出程序再进去,还是在。怎么退? OPPO手机如何退出阅读账号? 小说作者要退出该网站该如何退出 全本小说网怎么才能退出 软考软件设计师下午题的C++面向对象程序设计题有很多英语单词看不懂,这... QQ浏览器小说书架如何退出登录 关于软考软件设计师下午编程题 全本小说网怎么才能退出? 请问软考软件设计师下午题第一题是数据流图,第三题是UML是吗,这两题都... 有人骂你喜欢的明星怎么办?详细点说的 几个软考的题,求解答。 如何退出百度小说帐号 如果有人骂你家爱豆,夸她家爱豆怎么回击 曾经软考中的一道题 扑阅小说怎样退出登录? 爱豆被恶意辱骂,你会如何回复? 怎么从QQ浏览器中的小说里退出登录帐号 如果另一个明星粉丝骂爱豆怎么办? 我特别心疼自己的爱豆! 交被开水烫伤后起水泡被挑破了,要怎么继续处理呢? 被开水烫伤以后起的大水泡不小心被弄破了,而且烫伤处又红又疼,应该怎么处理? 白菜粉条炒大虾的做法,白菜粉条炒大虾怎么做 被水烫伤后起的水泡被弄破了怎么办 烧伤后起泡了就挑破了然后总流水怎么办啊? 虾仁白菜西红柿炖粉条的做法大全家常 一般用电饭煲蒸比较简单的菜,就是那种加点水放里面蒸,比如豆腐什么的,要蒸多久时间?给个大概就行 固定宽带的云服务器速度与用流量5-100m的云服务器的速度哪个更快? 看快手发现里的段孑怎么就跳到微信里让扫码呢 云服务器和云虚拟主机有什么区别的吗?? 正在看快手 微信一发红包 就自动转微信了 是怎么回事? 我买云服务器 他说1g空间流量 100m数据流量 2m宽带 20g流量分别是什么意思? 快手里怎么能链接到微信上 在打开微信链接时切换到快手为什么就不是微信里的链接视频了怎么办别人给我在微信里发的快手短视频分享_百度问一问 信用卡被盗刷的责任应该是谁负? 信用卡盗刷损失责任在中国法律上是怎么规定的 防雾泳镜怎么样 信用卡被盗刷了怎么办,银行会承担责任吗 梦见自己在海里游泳游的很快很轻松,轻而易举就能到岸边 信用卡被盗刷,什么情况下银行会承担责任进行赔偿