ResizedColTable.js
/**/
/***********************************
* 可变列宽的表格 V1.1 2007-01-01
* Author:lzb linzhuobin@gmail.com
* 2006-11-18 发布 V1.0
* 2007-01-01 V1.1 增加了列宽保持功能
***********************************/
data:image/s3,"s3://crabby-images/2f392/2f392241c4d571b25f75772d9fb75095e8cddba3" alt=""
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
function
ResizedColTable(tb)
...
{
var DEFAULT_COL_WIDTH=52;
var dragSpan=null, preWidth=0, preX=0, newWidth=0;
data:image/s3,"s3://crabby-images/1f733/1f7338478ceac99ac0555b5f2f8a6a38cb606897" alt=""
//改变列宽 (响应 onmousedown)
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function doMouseDown()...{
var evt = arguments.length==0 ? event : arguments[0];
dragSpan = evt.srcElement?evt.srcElement:evt.target;
preWidth = parseInt(dragSpan.firstChild.style.width);
preX = evt.x?evt.x:evt.pageX;
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
if(dragSpan.setCapture)...{
dragSpan.setCapture();
dragSpan.onmousemove = changeColWidth;
dragSpan.onmouseup = changeColWidthStop;
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
}else if(window.captureEvents)...{
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
document.onmousemove = changeColWidth;
document.onmouseup = changeColWidthStop;
}
}
//改变列宽 (响应 onmousemove)
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function changeColWidth()...{
var evt = arguments.length==0 ? event : arguments[0];
var newX = evt.x?evt.x:evt.pageX;
newWidth = newX - preX + preWidth;
if(newWidth<8) newWidth=8;
}
//改变列宽 (响应 onmouseup)
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function changeColWidthStop()...{
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
if(dragSpan.releaseCapture)...{
dragSpan.releaseCapture();
dragSpan.onmousemove = null;
dragSpan.onmouseup = null;
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
}else if(window.captureEvents)...{
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
document.onmousemove = null;
document.onmouseup = null;
}
dragSpan.firstChild.style.width = newWidth;
var i=dragSpan.parentNode.cellIndex;
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
for(var j=1;j<tb.rows.length;j++)...{
tb.rows[j].cells[i].firstChild.style.width=newWidth;
}
saveWidth();
}
//鼠标所在行高亮显示
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function doMouseOver()...{
this.className="dataRowSelected";
}
//鼠标移出行
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function doMouseOut()...{
this.className="dataRow"+(this.rowIndex%2);
}
//url+table.id 保证Cookie的唯一,以区别不同页面的同名控件
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function getCookieName()...{
var i=-1;
var url=window.location+"";
i=url.lastIndexOf("?");
if(i>0)url=url.substr(0,i);
i=url.indexOf("///");
if(i>0)url=url.substr(i+3,url.length-i-3);
i=url.indexOf("//");
if(i>0)url=url.substr(i+2,url.length-i-2);
i=url.indexOf("/");
if(i>0)url=url.substr(i,url.length-i);
return url+"$"+tb.id;
}
//保存列宽到Cookie
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function saveWidth()...{
var aWidth=new Array();
var ths = tb.rows[0].cells;
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
for(var i=0;i<ths.length;i++)...{
var sp=ths[i].firstChild;
aWidth.push(sp.firstChild.style.width);
}
var date = new Date();
date.setDate(date.getDate()+7);
//date.setSeconds(date.getSeconds()+7);
CookieHelper.setCookie(getCookieName(),aWidth,date);
}
//从Cookie初始化列宽
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
function initWidth()...{
var sWidth = CookieHelper.getValue(getCookieName());
if(!sWidth)return;
var aWidth=sWidth.split(",");
var ths = tb.rows[0].cells;
if(aWidth.length!=ths.length)return;
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
for(var i=0;i<ths.length;i++)...{
var sp=ths[i].firstChild;
sp.firstChild.style.width=aWidth[i];
}
}
//初始化
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
new function()...{
initWidth();
var ths = tb.rows[0].cells;
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
for(var i=0;i<ths.length;i++)...{
var sp=ths[i].firstChild;
if(sp.firstChild.style.width=="")sp.firstChild.style.width=DEFAULT_COL_WIDTH;
if(sp.fixed!="true") sp.onmousedown=doMouseDown;
else sp.style.cursor="default";
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
for(var j=1;j<tb.rows.length;j++)...{
var tr=tb.rows[j];
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
if(i==0)...{
tr.className="dataRow"+(j%2);
tr.onmouseover=doMouseOver;
tr.onmouseout=doMouseOut;
}
tr.cells[i].firstChild.style.width=sp.firstChild.style.width;
}
}
saveWidth();
}
}
data:image/s3,"s3://crabby-images/2f392/2f392241c4d571b25f75772d9fb75095e8cddba3" alt=""
//
cookie操作
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
function
CookieHelper()
...
{}
;
//
保存cookie
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
CookieHelper.setCookie
=
function
(name,value,expires,path,domain)
...
{
if(!name || !value) return;
var sCookie=name+"="+escape(value)+";";
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
if(expires)...{
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
try...{
sCookie+="expires="+expires.toGMTString()+";";
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
}catch(e)...{
}
}
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
if(path)...{
sCookie+="path="+path+";";
}
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
if(domain)...{
sCookie+="domain="+domain+";";
}
document.cookie=sCookie;
}
//
获取cookie值
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
CookieHelper.getValue
=
function
(sName)
...
{
var value=null;
var aCookie = document.cookie.split("; ");
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
for (var i=0; i < aCookie.length; i++)...{
var aCrumb = aCookie[i].split("=");
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
if (sName == aCrumb[0])...{
value=unescape(aCrumb[1]);
break;
}
}
return value;
}
style.css
.purpleTb
{...}
{
BORDER-RIGHT: #666666 1px solid; BORDER-TOP: #b5caff 1px solid; BORDER-LEFT: #b5caff 1px solid; BORDER-BOTTOM: #666666 1px solid
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb
{...}
{
FONT-SIZE: 12px
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .fieldTr
{...}
{
BACKGROUND-IMAGE: url(thbg.jpg); BACKGROUND-COLOR: #ece9d8
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .fieldTd
{...}
{
BORDER-RIGHT: #666666 1px solid; PADDING-RIGHT: 0px; BORDER-TOP: #fff 2px solid; PADDING-LEFT: 0px; FONT-WEIGHT: normal; PADDING-BOTTOM: 0px; BORDER-LEFT: #fff 1px solid; PADDING-TOP: 2px; BORDER-BOTTOM: #c0c0c0 1px solid; HEIGHT: 28px
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .fieldTd .fieldNowrapDiv
{...}
{
PADDING-RIGHT: 0px; PADDING-LEFT: 3px; PADDING-BOTTOM: 0px; OVERFLOW: hidden; CURSOR: default; PADDING-TOP: 3px; WHITE-SPACE: nowrap; TEXT-OVERFLOW: ellipsis
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .fieldTd .dragDiv
{...}
{
PADDING-RIGHT: 3px; DISPLAY: block; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; WIDTH: 100%; CURSOR: e-resize; PADDING-TOP: 0px
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .dataRow0
{...}
{
BACKGROUND-COLOR: #fafafa
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .dataRow1
{...}
{
BACKGROUND-COLOR: #fff
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .dataRowSelected
{...}
{
BACKGROUND-COLOR: #efefef
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .dataTd
{...}
{
BORDER-RIGHT: #b5caff 1px solid; PADDING-RIGHT: 3px; BORDER-TOP: #fff 1px solid; PADDING-LEFT: 0px; PADDING-BOTTOM: 0px; BORDER-LEFT: #fff 1px solid; PADDING-TOP: 0px; BORDER-BOTTOM: #b5caff 1px solid; HEIGHT: 22px
}
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
.purpleTb .dataTd .dataNowrapDiv
{...}
{
PADDING-RIGHT: 0px; PADDING-LEFT: 3px; PADDING-BOTTOM: 0px; OVERFLOW: hidden; PADDING-TOP: 3px; WHITE-SPACE: nowrap; TEXT-OVERFLOW: ellipsis
}
demo.htm
<
HTML
>
<
HEAD
>
<
META
http-equiv
=Content-Type
content
="text/html; charset=gb2312"
>
<
LINK
href
="style.css"
type
=text/css
rel
=stylesheet
>
<
SCRIPT
src
="ResizedColTable.js"
></
SCRIPT
>
data:image/s3,"s3://crabby-images/0e685/0e6853c0260e2415df4d3830d5db69e7c47ad377" alt=""
<
STYLE
>
...
BODY {...}{ MARGIN: 0px}</STYLE>
</HEAD>
<BODY>
data:image/s3,"s3://crabby-images/1f733/1f7338478ceac99ac0555b5f2f8a6a38cb606897" alt=""
<TABLE class=purpleTb id=table1 cellSpacing=0 cellPadding=0 border=0>
<TBODY>
<TR class=fieldTr>
<TH class=fieldTd>
<DIV class=dragDiv fixed="true">
<DIV class=fieldNowrapDiv onmousedown=event.cancelBubble=true; title=""
style="WIDTH: 35px">序号</DIV></DIV></TH>
<TH class=fieldTd>
<DIV class=dragDiv fixed="false">
<DIV class=fieldNowrapDiv onmousedown=event.cancelBubble=true; title=""
style="WIDTH: 130px">运行日程表达式</DIV></DIV></TH>
<TH class=fieldTd>
<DIV class=dragDiv fixed="false">
<DIV class=fieldNowrapDiv onmousedown=event.cancelBubble=true; title=""
style="WIDTH: 180px">下次运行时间</DIV></DIV></TH>
<TH class=fieldTd>
<DIV class=dragDiv fixed="false">
<DIV class=fieldNowrapDiv onmousedown=event.cancelBubble=true; title=""
style="WIDTH: 200px">程序标识</DIV></DIV></TH>
<TH class=fieldTd>
<DIV class=dragDiv fixed="false">
<DIV class=fieldNowrapDiv onmousedown=event.cancelBubble=true; title=""
style="WIDTH: 150px">描述</DIV></DIV></TH>
<TH class=fieldTd>
<DIV class=dragDiv fixed="false">
<DIV class=fieldNowrapDiv onmousedown=event.cancelBubble=true; title=""
style="WIDTH: 100px">操作</DIV></DIV></TH></TR>
<TR>
<TD class=dataTd>
<DIV class=dataNowrapDiv title=""
style="TEXT-ALIGN: center"><B>0</B></DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="">0 46 21 8 1 ?</DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="">2008年01月08日 21时46分00秒 </DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="">jobDetail_test</DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title=测试>测试</DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="" style="TEXT-ALIGN: center"><INPUT type=button value=修改日程></DIV></TD></TR>
<TR>
<TD class=dataTd>
<DIV class=dataNowrapDiv title=""
style="TEXT-ALIGN: center"><B>1</B></DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="">40 42 17 16 1 ?</DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="">2008年01月16日 17时42分40秒 </DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="">jobDetail_importXlsData</DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title=导入excel数据>导入excel数据</DIV></TD>
<TD class=dataTd>
<DIV class=dataNowrapDiv title="" style="TEXT-ALIGN: center"><INPUT type=button value=修改日程></DIV></TD></TR></TBODY>
</TABLE>
data:image/s3,"s3://crabby-images/1f733/1f7338478ceac99ac0555b5f2f8a6a38cb606897" alt=""
data:image/s3,"s3://crabby-images/40cf9/40cf9b1f5878639b203570f96454105d4ad75f39" alt=""
<SCRIPT>...new ResizedColTable(document.getElementById('table1'));</SCRIPT>
</BODY>
</HTML>
Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=1494472