jQuery表格列宽可变,兼容firfox
本demo使用jQuery包,实现表格列宽可拖拽功能,并实现页面reset时的重新布局。使用jQuery,方便函数的调用,给要处理的表格添加id 后,直接调用$("#id").movedTh()即可方便实现,修改了firfox的兼容性。
代码如下:
- <html>
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
- <mce:script type="text/javascript" src="jquery-1.3.2.min.js" mce_src="jquery-1.3.2.min.js"></mce:script>
- <mce:style><!--
- .resizeDivClass
- {
- position:absolute;
- background-color:gray;
- width:2px;
- height:15px;
- z-index:1px;
- display: block;
- cursor:e-resize
- }
- .td1 {
- font-size: 12px;
- white-space:nowrap;
- color:#0000ff;
- }
- --></mce:style><style mce_bogus="1">.resizeDivClass
- {
- position:absolute;
- background-color:gray;
- width:2px;
- height:15px;
- z-index:1px;
- display: block;
- cursor:e-resize
- }
- .td1 {
- font-size: 12px;
- white-space:nowrap;
- color:#0000ff;
- }</style>
- <mce:script language=javascript><!--
- /*
- 标题:扩拖拽列表格demo 1.2
- 设计:卢松强
- 博客:http://hi.csdn.net/andensy
- 日期:2010年4月26日
- 说明:修改了firfox兼容性问题,可以很好的兼容火狐浏览器
- */
- /*
- 依赖于jQuery
- */
- (function($){
- //用正则表达式判断jQuery的版本
- if (/1/.(0|1|2)/.(0|1|2|3|4|5)/.test($.fn.jquery) || /^1.1/.test($.fn.jquery)) {
- alert('movedTh 需要 jQuery v1.2.6 以后版本支持! 你正使用的是 v' + $.fn.jquery);
- return;
- }
- me=null;
- var ps=3;
- $.fn.movedTh=function(){
- me=this;
- var target = null;
- var tempStr = "";
- var i=0;
- $(me).find("tr:first").find("th").each(function(){
- tempStr = '<div id="mydiv'+i+'"onmousedown="$().mousedone.movedown(event,this)" ></div>';
- var div={};
- $(this).html($(this).html()+tempStr);
- var offset = $(this).offset();
- var pos=offset.left +$(this).width()+ me.offset().left-ps;
- $("#mydiv"+i).addClass("resizeDivClass");
- $("#mydiv"+i).css("left",pos);
- $("#mydiv"+i).css("top",(offset.top+2));
- i++;
- }); //end each
- } //end moveTh
- $.fn.mousedone={
- movedown:function(e,obj){
- var d=document;
- var e = window.event||e ;
- var myX = e.clientX||e.pageX;
- obj.mouseDownX=myX ;
- obj.pareneTdW=$(obj).parent().width(); //obj.parentElement.offsetWidth;
- obj.pareneTableW=me.width();
- if(obj.setCapture){
- obj.setCapture();
- }else if(window.captureEvents){
- window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
- }
- d.onmousemove=function(e){
- var dragData=obj;
- var event = window.event||e ;
- if(!dragData.mouseDownX) return false;
- var newWidth=dragData.pareneTdW*1+(event.clientX||event.pageX)*1-dragData.mouseDownX;
- if(newWidth>0)
- {
- $(obj).parent().width(newWidth);
- me.width(dragData.pareneTableW*1+(event.clientX||event.pageX)*1-dragData.mouseDownX);
- var k=0;
- me.find("tr:first").find("th").each(function(){
- var offset = $(this).offset();
- var pos=offset.left*1+$(this).width()*1+me.offset().left*1-ps;
- $("#mydiv"+k).css("left",pos);
- k++;
- }) //end each
- }//end if
- };
- d.onmouseup=function(e){
- var dragData=obj;
- if(dragData.setCapture)
- {
- dragData.releaseCapture();
- }else if(window.captureEvents){
- window.releaseEvents(e.MOUSEMOVE|e.MOUSEUP);
- }
- dragData.mouseDownX=0;
- }
- }
- } //end mousedone
- $(window).resize(function(){
- setTimeout(function() {
- var target = null;
- var tempStr = "";
- var i=0;
- $(me).find("tr:first").find("th").each(function(){
- tempStr = '<div id="mydiv'+i+'"onmousedown="$().mousedone.movedown(event,this)" ></div>';
- var div={};
- $(this).html($(this).html()+tempStr);
- var offset = $(this).offset();
- var pos=offset.left +$(this).width()+ me.offset().left-ps;
- $("#mydiv"+i).addClass("resizeDivClass");
- $("#mydiv"+i).css("left",pos);
- i++;
- }); //end each
- }, 10);
- });
- })(jQuery)
- $().ready(function(){
- $("#tab").movedTh();
- })
- // --></mce:script>
- </head>
- <body onload="">
- <table cellpadding="3" id='' STYLE="table-layout:fixed;" mce_STYLE="table-layout:fixed;" >
- <tr bgcolor=cccccc >
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr><span style="color:#069" mce_style="color:#069">|</span></th>
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr><span style="color:#069" mce_style="color:#069">|</span></th>
- </tr></table>
- <br>
- <table cellpadding="3" id='tab' STYLE="table-layout:fixed;" mce_STYLE="table-layout:fixed;" >
- <tr bgcolor=cccccc >
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr></th>
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr></th>
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr></th>
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr></th>
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr></th>
- <th valign=top class="td1" ><nobr>改变table的列宽度改</nobr></th>
- </tr>
- <tr>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- </tr>
- <tr>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- </tr>
- <tr>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- </tr>
- <tr>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- <td class="td1"><nobr>改变table的列宽度</nobr></td>
- </tr>
- </table>
- </body>
- </html>
jQuery表格列宽可变,兼容firfox的更多相关文章
- 使用jqueryUI实现自由调整表格列宽
今天项目中需要插入表格,用Excel表格调整列宽时,想怎么拖就怎么拖,于是乎就让插入的表格也这么让人舒服.网上查找许久,没找到好用的方案.最后发现jQuery UI中的resizable()方法可以实 ...
- 转!!Java JTable 根据表格内容 自动调整表格列宽
//根据表格内容 自动调整列宽http://blog.sina.com.cn/s/blog_5e54d6140100s1d3.html
- eas之添加表格列宽自动调整设置
设置表格整体宽度自动调整为所在panel的宽度 KDTable table=new KDTable(); table. setAutoResize (boolean); 注意:该功能在冻结功能启用后, ...
- java表格操作之设置表格列宽
设置所有列的宽度 /** * 设置所有列的列宽 * @param table * @param width */ public void setAllColumnWidth(JTable table, ...
- 原生js实现table表格列宽自由缩放
<!DOCTYPE html> <html> <head> <meta charset="gbk"> <title>ta ...
- 原生js实现 table表格列宽拖拽
查看效果 <!DOCTYPE html> <html> <head> <meta charset="gbk"> <title& ...
- JS实现表格列宽拖动
在数据表格中,有时候需要拖动表格宽度,查看完整的数据,是很常用的功能. 1 效果 可以用纯JS就可以实现,如下,是正常情况下的表格: 拖动表格标题中间线,拖动后效果如下: 查看DEMO 2 代码 HT ...
- JQuery 表格拖动调整列宽效果
类似于桌面程序中的表格拖动表头的效果,当鼠标停留在表头边框线上时,鼠标会变成表示左右拖动的形状,接着拖动鼠标,会在表格中出现一条随鼠标移动的竖线,最后放开鼠标,表格列宽会被调整.最近比较空闲,便自己动 ...
- QTableView表格视图的列宽设置
Qt中的表格控件可以通过从QTableView或QTableWidget派生子类实现.其中,QTableWidget只是对QTableView的一种简单封装.因为使用QTableView常常需要用户指 ...
随机推荐
- String、StringBuffer、StringBulider
三者都实现了CharSequence接口,因此CharSequence可认为是一个字符串的协议接口 1.String类是不可变类,即一旦一个String对象被创建后,包含在这个对象中的字符序列是不可改 ...
- 正则表达式(特殊字符)/Xpath语法/CSS选择器
正则表达式(特殊字符) ^ 开头 '^b.*'----以b开头的任意字符 $ 结尾 '^b.*3$'----以b开头,3结尾的任意字符 * 任意长度(次数),≥0 ? 非贪婪模式,非贪婪模式尽可能少的 ...
- DragonBones的下载和安装
DragonBones也称龙骨,是一款骨骼动画制作软件.DragonBones Pro是由Flash的龙骨骨骼动画插件进化而来的,与传统逐帧动画相比,骨骼动画资源较小且动画效果比较好. DragonB ...
- Structured Streaming教程(2) —— 常用输入与输出
上篇了解了一些基本的Structured Streaming的概念,知道了Structured Streaming其实是一个无下界的无限递增的DataFrame.基于这个DataFrame,我们可以做 ...
- [CGAL]带岛多边形三角化
CGAL带岛多边形三角化,并输出(*.ply)格式的模型 模型输出的关键是节点和索引 #include <CGAL/Triangulation_vertex_base_with_id_2.h&g ...
- vim中delete(backspace)键不能向左删除
MacOS修改为英文语言之后,忽然出现如题问题:delete键不能向左删除,只可以删除本次插入模式下插入的文本.原因: 转载:https://www.smslit.top/2016/11/27/vim ...
- Chromium OS 初体验
Chromium OS可是早有耳闻,但是一直没有尝试,最近很多评论甚至认为会对Windows和Mac都能够造成压力,于是迫不及待的想尝试一下了,百度下了官网,官网很贴心,不光给了用于写入U盘的镜像文件 ...
- linux-批量杀死进程
kill `ps -ef|grep 进程名 | grep -v grep|awk '{print $2}'` 例如: kill `ps -ef | grep /etc/pam.d/su |grep - ...
- Windows平台下tomcat 性能调优
Tomcat 线程查看工具: https://blog.csdn.net/jrainbow/article/details/49026365 16G内存 Tomcat并发优化.内存配置.垃圾回收.宕机 ...
- 基于Centos7.5搭建Docker环境
docker很火,基于容器化技术,实现一次编译到运行.实现运行环境+服务的一键式打包! 00.部署环境 centos7.5(基于vmware搭建的测试环境,可以跟互联网交互,桥接方式联网) docke ...