JavaScript 拖动改变面板大小

系统 2547 0
TAB.JPG

上面是实际效果,虽然丑陋。不过当时写这个效果的时候也并不顺利。

代码如下:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<style>
#tab
{
 table-layout:auto;
 border-collapse:collapse;
 border:1px solid #000000;
 width:100%;
}
div
{
 width:100%;
 margin:0px;
 padding:0px;
 overflow:auto;
 border: 1px solid #4CA2ED;
 background-color:#E8F2FE;
 font-size:9pt;
}
td
{
 position:relative;
 padding:0px;
 margin:0px;
}
</style>
<script type="text/javascript">
function $(dom_id)
{
 return document.getElementById(dom_id);
}
function MouseDownToResize(obj)

 obj.mouseDownY = event.clientY;
 $('td1').pareneTdH = $('td1').offsetHeight;
 $('td2').pareneTdH = $('td2').offsetHeight;
 $('td3').pareneTdH = $('td3').offsetHeight;
 $('tab').pareneTableH = $('tab').offsetHeight;
 obj.setCapture();//事件扩张
}
function MouseMoveToResize(obj)

 if(!obj.mouseDownY) return false;
 var newHeight = $('td2').pareneTdH*1+event.clientY*1-obj.mouseDownY;
 //拖动
 if((newHeight<0 && -1*newHeight<$('td1').pareneTdH )||(newHeight>0 && newHeight<$('td3').pareneTdH))
 {
    $('td1').style.height = $('td1').pareneTdH+newHeight;
    $('td3').style.height = $('td3').pareneTdH-newHeight;
 $('div1').style.height = $('td1').pareneTdH+newHeight;
    $('div3').style.height = $('td3').pareneTdH-newHeight;
 $('tab').style.height = $('tab').pareneTableH;
 window.status = newHeight +"||"+ $('td3').style.height;
 }
}
function MouseUpToResize(obj)
{
    obj.releaseCapture();
    obj.mouseDownY=0;
}
</script>
</head>
<body>
  <table id="tab" cellpadding="0" cellspacing="0">
    <tr><td valign=top id="td1"><div id="div1" style="height:250px;">
<pre> 
function $(dom_id)
{
 return document.getElementById(dom_id);
}
function MouseDownToResize(obj)

 obj.mouseDownY = event.clientY;
 $('td1').pareneTdH = $('td1').offsetHeight;
 $('td2').pareneTdH = $('td2').offsetHeight;
 $('td3').pareneTdH = $('td3').offsetHeight;
 $('tab').pareneTableH = $('tab').offsetHeight;
 obj.setCapture();//事件扩张
}
function MouseMoveToResize(obj)

 if(!obj.mouseDownY) return false;
 var newHeight = $('td2').pareneTdH*1+event.clientY*1-obj.mouseDownY;
 //拖动
 if((newHeight<0 && -1*newHeight<=$('td1').pareneTdH )||(newHeight>0 && newHeight<=$('td3').pareneTdH))
 {
    $('td1').style.height = $('td1').pareneTdH+newHeight;
    $('td3').style.height = $('td3').pareneTdH-newHeight;
 $('div1').style.height = $('td1').pareneTdH+newHeight;
    $('div3').style.height = $('td3').pareneTdH-newHeight;
 $('tab').style.height = $('tab').pareneTableH;
 window.status = newHeight +"||"+ $('td3').style.height;
 }
}
function MouseUpToResize(obj)
{
    obj.releaseCapture();
    obj.mouseDownY=0;
}
</pre>
 </div></td></tr>
 <tr bgcolor="#000" height="2" onmousedown="MouseDownToResize(this);" onmousemove="MouseMoveToResize(this);" onmouseup="MouseUpToResize(this);" style="cursor:n-resize;"><td id="td2"></td></tr>
 <tr><td id="td3"><div id="div3" style="height:150px;"></div></td></tr>
  </table>
</body>
</html>

JavaScript 拖动改变面板大小


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论