获取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"%><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><link href="../resource/css/css.css" rel="stylesheet" type="text/css" /><script type="text/javascript" src="../resource/js/CloneTableHeader.js"></script><script type="text/javascript">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; }</script></head><body><form action="action" method="post" id="report"><div style=" width:100%;height:400px; overflow:scroll;overflow-x: hidden;" id="div1"> <table cellpadding="0" id="tab1" cellspacing="0" border="0" class="itemList"> <thead> <tr style="background-color: #eeeeee; margin: 0px; line-height: 20px; font-weight: bold; padding: 0px 0px 0px 0px;"> <td width="2%" height="24">1</td> <td width="2%">2</td> <td width="2%">3</td> <td width="2%">4</td> <td width="2%">5</td> <td width="2%">6</td> <td width="2%">7</td> </tr> </thead><s:iterator id="result" value="workTypeList"> <tr id="<s:property value="id"/>" onmouseover="this.className='td_over'" onmouseout="this.className='td_default'" class="td_default"> <td width="2%" align="left" valign="middle"><input type="text" name="recordNumber" onchange="javascript:getNewTotal('<s:property value="id"/>');" style= "border:0px;width:94%" maxlength="4" /></td> <td width="2%" align="left" valign="middle"><input type="text" name="recordNumber" onchange="javascript:getNewTotal('<s:property value="id"/>');" style= "border:0px;width:94%" maxlength="4" /></td> <td width="2%" align="left" valign="middle"><input type="text" name="recordNumber" onchange="javascript:getNewTotal('<s:property value="id"/>');" style= "border:0px;width:94%" maxlength="4" /></td> <td width="2%" align="left" valign="middle"><input type="text" name="recordNumber" onchange="javascript:getNewTotal('<s:property value="id"/>');" style= "border:0px;width:94%" maxlength="4" /></td> <td width="2%" align="left" valign="middle"><input type="text" name="recordNumber" onchange="javascript:getNewTotal('<s:property value="id"/>');" style= "border:0px;width:94%" maxlength="4" /></td> <td width="2%" align="left" valign="middle"><input type="text" name="recordNumber" onchange="javascript:getNewTotal('<s:property value="id"/>');" style= "border:0px;width:94%" maxlength="4" /></td> <td width="2%" align="left" valign="middle"><input type="text" name="recordNumber" onchange="javascript:getNewTotal('<s:property value="id"/>');" style= "border:0px;width:94%" maxlength="4" /></td> </tr></s:iterator></table></div> </form></body></html>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());} 问题补充:redstarofsleep 写道

解决方案

在你的第40行加上这个$(jQuery(table).find("tbody")[0]).empty();也就是这一行的前面 var headerDiv = document.createElement("div");同时注意 你用这个插件时一定要有THEAD,和TBODY标签 ,不然会报错
解决方案二:
你把CloneTableHeader.js这个当附件 传一下,得改这个插件
解决方案三:
<script type="text/javascript" src="jquery.js"></script><script type="text/javascript">$(document).ready(function(){ $("button").click(function(){ alert($("#uName").val()); });});</script><input type="text" id="uName" /><input type="button" value="获取" />
解决方案四:
你先把id打出来看看,然后再把a的length打出来看看有没有拿到
解决方案五:
不知道是不是你导入的JS做了什么操作,你看看最后生成的页面代码。你是要做表头固定吗?我博客里有,纯CSS实现的。http://redstarofsleep.iteye.com/blog/1010569
解决方案六:
可以用jquery的选择器啊var $inputs = $('#'+id+' input');
解决方案七:
getNewTotal这个里面的id是什么东西的id?td的?你的td没有id啊?
解决方案八:
引用在</thead> 后加<tbody>吗 是的,把后面的内容都包进去
解决方案九:
要取值的东西放在一个<tbody>里面

时间: 2024-08-31 19:26:14

获取input 异常的相关文章

html5 获取input内容

 <!doctype html>  <html>  <head>  <meta charset=utf-8 />  <title>html5 获取input内容</title>  </head>  <body>    <input type="email" />    <input type="tel" />    <input type=&

redis-Redis无法获取连接异常

问题描述 Redis无法获取连接异常 最近搞缓存,所以折腾了一下redis,用jedis连接redis,发现在64位windows下运行一段时间就报错了Accepting client connection: accept: Unknown error, 然后jedis就一直连接超时是服务器停了.重启一下redis就又能连接上了.redis配置的日志级别是debug,也没抛其他错误,看了连接数也就我一个.纠结啊.... 解决方案 这个看上去是redis的bug,试试新版本呢. 解决方案二: Io

js-求救 ie11 如何获取 input 中选择的文本

问题描述 求救 ie11 如何获取 input 中选择的文本 IE其他版本的获取方式如下: var isIE=!!document.all; if(isIE){ var rng=window.getSelection.createRange(); str = rng.text; } else { var s = window.getSelection(); str = s.toString(); } 请问IE11下如何获取? 解决方案 I think I found a solution. No

mvc前台用@写代码时如何获取input的value值或js的变量值

问题描述 mvc前台用@写代码时如何获取input的value值或js的变量值 <script> $('input[name=c1]').change(function () { var value1 = $(this).val(); var value2 = $('input[name=c2]').val(); var value3 = $('input[name=c3]') if (value2 != """") { value3.val(@Calc

获取input表签的值-在webbrowser控件中获取文本框的值

问题描述 在webbrowser控件中获取文本框的值 复制授权码 请问高手们怎么才能获取到input标签的值呢 相关文章 javaweb-value为空,如何获取文本框的值? javascript-在js中 如何用Jquery 获取一个文本框中的值 文本框中ID=A js文本框-js获取文本框的值,有默认值 javascript-如何获取HTML网页密码输入框的值? jquery怎么让循环的两个文本框的值相加 servlet-想通过href链接传递文本框的值,该怎么得到文本框的值 textbox

html js java-如何获取Input type=file 所选择文件的绝对路径

问题描述 如何获取Input type=file 所选择文件的绝对路径 是这样的 现在做的一个项目,页面很简单 左边一个input输入框 可以在里面输入url 右边一个search按钮 当输入框没有输入东西的时候,点击按钮弹出一个上传文件选择的框 所选择的文件的 绝对路径会显示在输入框里 如果输入框有东西 URL是否存在,如果存在 则弹出的上传文件选择框定位在所输入的URL上面 但是现在第一步我就不知道怎么做了,除了ie 别的浏览器选择的文件都只显示文件名 请问有什么办法可以获取到所选择文件的绝

android sdk 4.2获取apn异常,难道不能获取了

问题描述 android sdk 4.2获取apn异常,难道不能获取了 android sdk 4.2使用apn异常,难道谷歌不让获取了?有方法解决吗 解决方案 没找到解决办法,只好取消对apn的信息读取了 解决方案二: Resolve: Phone must be rooted open and edit file /system/build.prop look for a line: telephony.rilV7NeedCDMALTEPhone set = false, or delete

hibernate-Hibernate无法获取session异常

问题描述 Hibernate无法获取session异常 java.lang.ClassNotFoundException: org.hibernate.Session at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1645) at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.jav

href-求大神指导如何能够获取input里面的值

问题描述 求大神指导如何能够获取input里面的值 参加人数: 源码显示: 解决方案 href=""./actbm?usernum=document.getElementById('input的id值').value 解决方案二: jQuery写法-- href=""./actbm?usernum=""+$(""#usernum"").val(); 解决方案三: <a href=""