liuluoqiu 2011-05-11 16:24 采纳率: 0%
浏览 280
已采纳

获取input 异常

我是在网上找了个可以固定表头的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"%>



jQuery(function() { jQuery.fn.CloneTableHeader("tab1", "div1"); }); function getNewTotal(id){ var a=document.getElementById(id).getElementsByTagName("input"); var total=0; for(var j=0;j<a.length;j++){ if(a[j].value!="" && isNaN(a[j].value)==false){ total=total+parseInt(a[j].value); } } //var row=document.getElementById(id); // row.cells[row.cells.length-1].innerText=total; }


" onmouseover="this.className='td_over'" onmouseout="this.className='td_default'" class="td_default">
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());

}

  • 写回答

9条回答 默认 最新

  • suziwen 2011-05-11 20:37
    关注

    在你的第40行

    加上这个

    [code="js"]$(jQuery(table).find("tbody")[0]).empty();
    [/code]
    也就是这一行的前面
    [code="js"] var headerDiv = document.createElement("div");[/code]

    同时注意 你用这个插件时一定要有THEAD,和TBODY标签 ,不然会报错

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(8条)

报告相同问题?

悬赏问题

  • ¥15 使用C#,asp.net读取Excel文件并保存到Oracle数据库
  • ¥15 C# datagridview 单元格显示进度及值
  • ¥15 thinkphp6配合social login单点登录问题
  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 虚心请教几个问题,小生先有礼了
  • ¥30 截图中的mathematics程序转换成matlab