Easyui Datagrid扩展fixRownumber方法

本文介绍了一种解决 EasyUI Datagrid 中 Rownumber 显示不全的问题的方法。通过扩展 Datagrid 的方法,使 Rownumber 在达到较大数值时也能正确显示,并提供了具体的实现代码及使用方式。


原创地址:  http://www.jeasyuicn.com/easyui-datagrid-extended-fixrownumber-method.html


相信很多人在使用easyui的时候都遇到过这个问题,当我们设置成显示Rownumber的时候,你会发现,如果Rownumber越来越大,达到三位数或者四位数的时候,Rownumber就显示不全了.这个问题纠结了不知道多少人,在群里和论坛里面都的都被问到无数次了. 以前也一直没有太认真考虑过要解决这个问题,恰好最近有点时间,就研究了一下,其实要解决也很简单,扩展一个方法就行了.

首先,从datagrid生成的代码,我们可以发现,在rowNumber上都有特定的class标记,datagrid-cell-rownumber,datagrid-header-rownumber.既然有规则可循,那么接下来的扩展就好办了......

下面直接贴出方法的扩展代码:



/**
 * 重新easyui-datagrid行号自适应
 */
$.extend($.fn.datagrid.methods, {
	fixRownumber : function(jq) {
		return jq.each(function() {
			var panel = $(this).datagrid("getPanel");
			//获取最后一行的number容器,并拷贝一份 
			var clone = $(".datagrid-cell-rownumber", panel).last().clone();
			//由于在某些浏览器里面,是不支持获取隐藏元素的宽度,所以取巧一下 
			clone.css({
				"position" : "absolute",
				left : -1000
			}).appendTo("body");
			var width = clone.width("auto").width();
			//默认宽度是25,所以只有大于25的时候才进行fix 
			if (width > 25) {
				//多加5个像素,保持一点边距 
				$(".datagrid-header-rownumber,.datagrid-cell-rownumber", panel).width(width + 5);
				//修改了宽度之后,需要对容器进行重新计算,所以调用resize 
				$(this).datagrid("resize");
				//一些清理工作 
				clone.remove();
				clone = null;
			} else {
				//还原成默认状态 
				$(".datagrid-header-rownumber,.datagrid-cell-rownumber", panel).removeAttr("style");
			}
		});
	}
});


有了方法,那要怎么使用,在什么时候使用呢?答案是:onLoadSuccess事件,所以就有如下,


$("#easyui-datagrid").datagrid({
	onLoadSuccess : function () {
		$(this).datagrid("fixRownumber");
	}
});



评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值