我是在网上找了个可以固定表头的jquery代码,但是表头是固定好了,但是td的input取值却不到了,假如我修改了input的值,但是getNewTotal函数中根据行获得tr中的input值却还是空值。请大家帮我看看,感觉太怪了
jsp页面:
<%@ page language="java" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%@ include file="/common/taglibs.jsp"%>
1 | 2 | 3 | 4 | 5 | 6 | 7 |
');" style= "border:0px;width:94%" maxlength="4" /> | ');" style= "border:0px;width:94%" maxlength="4" /> | ');" style= "border:0px;width:94%" maxlength="4" /> | ');" style= "border:0px;width:94%" maxlength="4" /> | ');" style= "border:0px;width:94%" maxlength="4" /> | ');" style= "border:0px;width:94%" maxlength="4" /> | ');" style= "border:0px;width:94%" maxlength="4" /> |
CloneTableHeader.js如下:
jQuery.fn.CloneTableHeader = function(tableId, tableParentDivId) {
var obj = document.getElementById("tableHeaderDiv" + tableId);
if (obj) {
jQuery(obj).remove();
}
var browserName = navigator.appName;
var ver = navigator.appVersion;
var browserVersion = parseFloat(ver.substring(ver.indexOf("MSIE") + 5, ver.lastIndexOf("Windows")));
var content = document.getElementById(tableParentDivId);
var scrollWidth = content.offsetWidth - content.clientWidth;
var tableOrg = jQuery("#" + tableId)
var table = tableOrg.clone();
table.attr("id", "cloneTable");
var tableClone = jQuery(tableOrg).find("tr").each(function() {
});
var tableHeader = jQuery(tableOrg).find("thead");
var tableHeaderHeight = tableHeader.height();
tableHeader.hide();
var colsWidths = jQuery(tableOrg).find("tbody tr:first td").map(function() {
return jQuery(this).width();
});
var tableCloneCols = jQuery(table).find("thead tr:first td")
if (colsWidths.size() > 0) {
for (i = 0; i < tableCloneCols.size(); i++) {
if (i == tableCloneCols.size() - 1) {
if (browserVersion == 8.0)
tableCloneCols.eq(i).width(colsWidths[i] + scrollWidth);
else
tableCloneCols.eq(i).width(colsWidths[i]);
} else {
tableCloneCols.eq(i).width(colsWidths[i]);
}
}
}
var headerDiv = document.createElement("div");
headerDiv.appendChild(table[0]);
jQuery(headerDiv).css("height", tableHeaderHeight);
jQuery(headerDiv).css("overflow", "hidden");
jQuery(headerDiv).css("z-index", "20");
jQuery(headerDiv).css("width", "100%");
jQuery(headerDiv).attr("id", "tableHeaderDiv" + tableId);
jQuery(headerDiv).insertBefore(tableOrg.parent());
}
在你的第40行
加上这个
[code="js"]$(jQuery(table).find("tbody")[0]).empty();
[/code]
也就是这一行的前面
[code="js"] var headerDiv = document.createElement("div");[/code]
同时注意 你用这个插件时一定要有THEAD,和TBODY标签 ,不然会报错
要取值的东西放在一个
里面[quote]在 后加
吗 [/quote]getNewTotal这个里面的id是什么东西的id?td的?你的td没有id啊?
可以用jquery的选择器啊
var $inputs = $('#'+id+' input');
不知道是不是你导入的JS做了什么操作,你看看最后生成的页面代码。
你是要做表头固定吗?我博客里有,纯CSS实现的。
http://redstarofsleep.iteye.com/blog/1010569
你先把id打出来看看,然后再把a的length打出来看看有没有拿到
$(document).ready(function(){ $("button").click(function(){ alert($("#uName").val()); }); });你把CloneTableHeader.js这个当附件 传一下,得改这个插件