JSP用中收集数据:javascript 实现输入多行动态输入


JSP用中收集数据:javascript 实现输入多行动态输入 
在网上找了一下,只有一篇此类文章,还是PHP的,害得我要特意去看一下PHP,感觉很不好,是一种弱类型的语言,可以不声明就使用,因此,还要在每个变量前加$.不知道那些高手们为什么不谈谈自己写过报关系统等时候,一次性动态输入多行数据的经历.
一般,我们用
request.getParameter("value");
来获得静态HTML输入的值.然后不要忘记判断是否为空,是否含有特殊字符等.
还可以用
Enumeration paramNames=request.getParameterNames();
while(paramNames.hasMoreElements()){String paramName=(String)paramNames.nextElement();}
来收集<input type="text" name="name"/>中的name
但是我们每增加新的一行,参数名同上一行一样,那么,我们将如何获得value的值?
这里我又去看书(servlet 和 JSP 核心编程,极好的一本书,该讲的都讲了,读明白了它servlet/JSP也就可以说精通了)p70页里面:getParameterValues()返回字符串数组,然后我们用循环判断这个字符串数组的长度,再就是获得值了:)

request.getParameter("value");//这个最熟悉,获得文本框的值
(Enumeration)request.getParameterNames();//获得文本框的名字
(String[])request.getParameterValues(paramName);//获得静态HTML页相同的参数(多次出现)的值
*************HTML 页 javascript 代码:
<script language="javascript">
function tbladdrow()
{
        var i=lines.rows.length;
        var row = Table1.insertRow(Table1.rows.length);
        var col = row.insertCell(0);
        col.innerHTML = "<INPUT id=line["+i+"][name1] name=line"+i+"name1 SIZE=10>";
        col = row.insertCell(1);
        col.innerHTML = "<INPUT id=line["+i+"][name2]  name=line"+i+"name2 SIZE=10>";
        col = row.insertCell(2);
        col.innerHTML = "<INPUT id=line["+i+"][name3] name=line"+i+"name3 SIZE=10>";
        col = row.insertCell(3);
        col.innerHTML = "<INPUT id=line["+i+"][name4] name=line"+i+"name4 SIZE=10>";
}
function tbladdrows(items)
{
        for( i = 1 ; i <= items ; i++)
        {
                tbladdrow();
        }
}
function delrow()
{
        if(lines.rows.length==0)
        {
                return false  ;
        }
        lines.deleteRow();
}
</script>
****************HTML页其它代码:
<HTML>
  <head>
    <meta http-equiv="Content-Type" content="text/HTML; charset=Big5">
    <title>输入</title>
  </head>
  <body>
 <form action="getInput.JSP">
  <DIV align=center><FONT size=2>输入测试</FONT></DIV></TD>
    <TD width=412 bgColor=#e4e4e4>
      <TABLE id=Table1 cellSpacing=0 borderColorDark=#ffffff cellPadding=0 
      width=350 align=center borderColorLight=#000000 border=1>
        <TBODY>
        <TR bgColor=#999999>
          <TH width=94><FONT size=2>参数一</FONT></TH>
          <TH width=84><FONT size=2>参数二</FONT></TH>
          <TH width=85><FONT size=2>参数三</FONT></TH>
          <TH width=77><FONT size=2>参数四</FONT></TH></TR>
        <TBODY id=lines name="lines"><!--
         <TR>
             <TD><INPUT id="things_name" TYPE="text" NAME="things_name" SIZE="15"></TD>
             <TD><INPUT id="things_model" TYPE="text" NAME="things_model" SIZE="10"></TD>
             <TD><INPUT id="things_number" TYPE="text" NAME="things_number" SIZE="5"></TD>
             <TD><input id="things_unit" type="text" name="things_unit" size="5"></TD>
         </TR>
                         --></TBODY></TABLE>
      <DIV align=center><BR></DIV>
      <DIV align=center>
      <INPUT id=items type=hidden value=1 name=items> <INPUT onclick=tbladdrow(items.value); 
type=button value=新增一行 name=insert/> 
      <font color="#e4e4e4"> </font>&nbsp;&nbsp;
      <INPUT language=javascript onclick="return delrow()" type=button value=删除一行 name=del/> 
      </DIV></TD></TR></TBODY></TABLE>
<input type="submit" value="commit"/>
</form>
  </body>
</HTML>
***JSP页收集输入
<%@ page contentType="text/HTML;charset=Big5"%>
<%@ page import="java.util.*"%>
<%
request.setCharacterEncoding("big5");
Enumeration paramNames=request.getParameterNames();
String paramName=null;
 while(paramNames.hasMoreElements()){
 paramName=(String)paramNames.nextElement();
 
 String param=request.getParameter(paramName);
 
 //out.println(paramName+"   "+param+"<br>");
 
  String paramValues[]=request.getParameterValues(paramName);
  for(int i=0; i<=paramValues.length-1; i++)
 {
 out.println(paramName+"  ");
 out.println(paramValues[i]+"<br>");}

本文作者:



相关阅读:
Ext.get() 和 Ext.query()组合使用实现最灵活的取元素方式
gpedit.msc禁止运行系统被锁死解决方法
比Jquery的document.ready更快的方法
SQLServer2005与SQLServer2008数据库同步图文教程
javascript实例教程(7)
JS统计Flash被网友点击过的代码
Oracle Apps DBA工作小结
如何通过程序修改ACCESS主窗体的标题和图标
关于HTML及UBB标记的闭合
出错提示与对策
ubuntu借助compiz实现终端嵌入桌面
作用相似html标记:strong与em、q、cite、blockquote
使用AJAX技术打造博客无刷新搜索引擎
提高网站性能之 如何对待JavaScript
快速导航

Copyright © 2016 phpStudy |