拖动改变Table的列宽度

收藏自:http://www.cnblogs.com/xieex/archive/2007/12/15/996025.html

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<style>
.resizeDivClass
{
position:relative;
background
-color:red;
width:
2;
z
-index:1;
left:expression(
this.parentElement.offsetWidth-1);
cursor:e
-resize;
}

</style>
<script language=javascript>
function MouseDownToResize(obj){
obj.mouseDownX
=event.clientX;
obj.pareneTdW
=obj.parentElement.offsetWidth;
obj.pareneTableW
=theObjTable.offsetWidth;
obj.setCapture();
}

function MouseMoveToResize(obj){
    
if(!obj.mouseDownX) return false;
    
var newWidth=obj.pareneTdW*1+event.clientX*1-obj.mouseDownX;
    
if(newWidth>0)
    
{
obj.parentElement.style.width 
= newWidth;
//theObjTable.style.width=obj.pareneTableW*1+event.clientX*1-obj.mouseDownX;
}

}

function MouseUpToResize(obj){
obj.releaseCapture();
obj.mouseDownX
=0;
}

</script>
</head>
<body>
拖动表列改变table的列宽度
<table id=theObjTable STYLE="table-layout:fixed" >
<tr bgcolor=cccccc >
<td valign=top >
<font class="resizeDivClass" onmousedown="MouseDownToResize(this);" 
onmousemove
="MouseMoveToResize(this);" onmouseup="MouseUpToResize(this);"></font>
列一
</td>
<td valign=top >
<font class="resizeDivClass" onmousedown="MouseDownToResize(this);" 
onmousemove
="MouseMoveToResize(this);" onmouseup="MouseUpToResize(this);"></font>
列二
</td>
<td valign=top >
<font class="resizeDivClass" onmousedown="MouseDownToResize(this);" 
onmousemove
="MouseMoveToResize(this);" onmouseup="MouseUpToResize(this);"></font>
列三
</td>
</tr>
<tr>
<td>拖动表列改变table的列宽度</td><td>拖动表列改变table的列宽度</td><td>拖动表列改变table的列宽度</td>
</tr>
</table>
</body>
</html>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 HTML 表格宽度拖拽,可以使用原生 JavaScript 来实现。以下是一个简单的实现方式: HTML 代码: ``` <table id="myTable"> <tr> <th>1</th> <th>2</th> <th>3</th> </tr> <tr> <td>内容1</td> <td>内容2</td> <td>内容3</td> </tr> <tr> <td>内容4</td> <td>内容5</td> <td>内容6</td> </tr> </table> ``` JavaScript 代码: ``` var table = document.getElementById("myTable"); var isResizing = false; var lastDownX = 0; // 设置每的初始宽度 var columnWidths = [100, 100, 100]; for (var i = 0; i < table.rows[0].cells.length; i++) { table.rows[0].cells[i].style.width = columnWidths[i] + "px"; } // 鼠标按下时记录位置 table.addEventListener("mousedown", function (e) { isResizing = true; lastDownX = e.clientX; }); // 鼠标移动时改变宽度 table.addEventListener("mousemove", function (e) { if (!isResizing) { return; } var cell = e.target.parentElement; var cellIndex = Array.from(cell.parentElement.children).indexOf(cell); var widthDiff = e.clientX - lastDownX; // 改变当前宽度 var newWidth = columnWidths[cellIndex] + widthDiff; if (newWidth > 0) { cell.style.width = newWidth + "px"; columnWidths[cellIndex] = newWidth; lastDownX = e.clientX; } }); // 鼠标抬起时停止改变宽度 table.addEventListener("mouseup", function (e) { isResizing = false; }); ``` 以上代码会在表格中添加一个鼠标事件监听器,当用户按下鼠标并移动时,会根据鼠标的位置改变被选中宽度。需要注意的是,当用户拖动宽度时,应该记录每的初始宽度(在这里使用了 `columnWidths` 数组来记录),并在移动过程中修改当前宽度,而不是仅仅修改当前宽度
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值