JS实现表格一列宽度拖拽

该博客介绍了如何使用JavaScript实现HTML表格中列宽的拖动调整功能。通过添加鼠标事件监听,当鼠标进入表格列头时,改变鼠标样式,允许用户通过拖动调整列宽。代码示例中包含了实现这一功能的关键函数和CSS样式。
摘要由CSDN通过智能技术生成
Code:
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  2. <html xmlns="http://www.w3.org/1999/xhtml">  
  3.   
  4. <head>  
  5. <script language="javascript" src="../JS/jquery-1.3.2-vsdoc2.js"></script>  
  6.     <title>ResizeTable</title>  
  7.     <style type="text/css">  
  8.         td, th   
  9.         {   
  10.             height: 20px;   
  11.             border: solid 1px black;   
  12.         }   
  13.     body   
  14.     {   
  15.         overflow:scroll;   
  16.     }   
  17.     </style>  
  18.   
  19.     <script type="text/javascript">  
  20.   
  21.         function getoffset(src) {   
  22.             var ct = 0; //获取控件相对于顶部的位置   
  23.             var cl = 0; //获取控件相对于左边的位置   
  24.             var p = src;   
  25.             while (p.offsetParent) {   
  26.                 ct += p.offsetTop;   
  27.                 cl += p.offsetLeft;   
  28.                 pp = p.offsetParent;   
  29.             }   
  30.             return [ct, cl, src.clientWidth, src.clientHeight]   
  31.         }   
  32.         function enter(src, e) {   
  33.   
  34.             if (!document.down) {   
  35.                 document.resizeControl = src;   
  36.             }   
  37.         }   
  38.   
  39. //        $(document).ready(function() {   
  40. //        $("th").mouseover(function() {   
  41. //        $("th").style.cursor = "W-resize";   
  42. //            });   
  43. //        } );   
  44.         //鼠标松开实现方法,设置图标为箭头,清空一些全局变量。重置document.down = null  
  45.         document.onmouseup = function() {   
  46.             document.down = null;   
  47.             var src = document.resizeControl;   
  48.             if (src) {   
  49.                 src.style.cursor=null;   
  50.                 src.resize = null;   
  51.                 src.srcData = null;   
  52.                 document.resizeControl = null;   
  53.   
  54.             }   
  55.         }   
  56.         //鼠标点击方法,   
  57.         document.onmousedown = function(e) {   
  58.             document.down = 1;   
  59.             if (document.resizeControl) {   
  60.                 var src = document.resizeControl;   
  61.                 var srcData = getoffset(src);   
  62.                 var eev = e || event;   
  63.                 var cX = ev.clientX;   
  64.                 var cY = ev.clientY;   
  65.                 if (cY >= srcData[0] && cY <= srcData[0] + srcData[3] && cX >= srcData[1] + srcData[2] - 10 && cX <= srcData[1] + srcData[2]) {   
  66.                     src.srcData = [src.clientWidth, ev.clientX];   
  67.                     src.resize = 1;   
  68.                 }   
  69.             }   
  70.         }   
  71.         //鼠标移动方法   
  72.         document.onmousemove = function(e) {   
  73.             if (document.resizeControl) {   
  74.                 var src = document.resizeControl;   
  75.                 var srcData = getoffset(src);   
  76.                 var eev = e || event;   
  77.                 var cX = ev.clientX;   
  78.                 var cY = ev.clientY;   
  79.                 //如果可以扩充,则改变鼠标样子。   
  80.                 if (cY >= srcData[0] && cY <= srcData[0] + srcData[3] && cX >= srcData[1] + srcData[2] - 10 && cX <= srcData[1] + srcData[2]) {   
  81.                    
  82.                     src.style.cursor = "W-resize";   
  83.                 }   
  84.                 else {   
  85.                     if (!document.down) {   
  86.                         src.style.cursor = null;   
  87.                     }   
  88.                 }   
  89.                 if (document.down && src.resize) {   
  90.                     // 自身长度+增量   
  91.                     //var newWidth = 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值