gsb490363212 2008-10-15 23:48
浏览 200
已采纳

jsp 文本值的读取 插入数据库

大概是这样的 前台页面的table中的tr 用js可以自动添加


(行可以自动加 每行文本name对应相等)


后台读取文本区的值,读取

一行就向数据库插入一行记录
例如:前台用户填写了5行 则后台读去保存5行

因为行数不确定 每行文本的name也一样 怎么读去保存实现啊? :cry:
[b]问题补充:[/b]
我的前台页面是这样的...怎么写save.jsp 保存把每行数据插入数据库~~~~??????


addRow function addRow() { if(document.all.tmpTitle.value==""){ alert("请先输入标题!"); } else{ var mytitle = document.getElementById("tmpTitle"); var am = document.getElementById("am"); var pr = document.getElementById("pr"); var zo = document.getElementById("zo"); var mytb = document.getElementById("myTable"); var mytr=mytb.insertRow();//加行 mytr.style.backgroundColor = "#ffffcc"; mytd=mytr.insertCell();//加单元格 mytd.align="left"; mytd.innerHTML= '<input type="text" name="merchant" style="WIDTH: 90%" value="'+mytitle.value+'" />'; mytd=mytr.insertCell(); mytd.align="left"; mytd.innerHTML= '<input type="text" name="merchant" style="WIDTH: 90%" value="'+am.value+'" />'; mytd=mytr.insertCell(); mytd.align="left"; mytd.innerHTML= '<input type="text" name="merchant" style="WIDTH: 90%" value="'+pr.value+'" />'; mytd=mytr.insertCell(); mytd.align="left"; mytd.innerHTML= '<input type="text" name="merchant" style="WIDTH: 90%" value="'+zo.value+'" />'; mytd=mytr.insertCell(); mytd.align="left"; mytd.innerHTML='<input type="button" value="删除" onclick="javaScript:document.all.myTable.deleteRow(event.srcElement.parentElement.parentElement.rowIndex);" />'; } }


商品 数量 单价 小计 操作


  • 写回答

5条回答 默认 最新

  • weixin_42299133 2008-10-27 11:08
    关注

    在网上找了一下,只有一篇此类文章,还是php的,害得我要特意去看一下php,感觉很不好,是一种弱类型的语言,可以不声明就使用,因此,还要在每个变量前加$.不知道那些高手们为什么不谈谈自己写过报关系统等时候,一次性动态输入多行数据的经历.

    一般,我们用
    request.getParameter("value");
    来获得静态HTML输入的值.然后不要忘记判断是否为空,是否含有特殊字符等.

    还可以用
    Enumeration paramNames=request.getParameterNames();
    while(paramNames.hasMoreElements()){String paramName=(String)paramNames.nextElement();}
    来收集中的name

    但是我们每增加新的一行,参数名同上一行一样,那么,我们将如何获得value的值?
    这里我又去看书(servlet 和 JSP 核心编程,极好的一本书,该讲的都讲了,读明白了它servlet/JSP也就可以说精通了)p70页里面:getParameterValues()返回字符串数组,然后我们用循环判断这个字符串数组的长度,再就是获得值了:)

    request.getParameter("value");//这个最熟悉,获得文本框的值
    (Enumeration)request.getParameterNames();//获得文本框的名字
    (String[])request.getParameterValues(paramName);//获得静态html页相同的参数(多次出现)的值

    *************html 页 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(); }

    ****************html页其它代码:



    輸入



    輸入測試


    width=350 align=center borderColorLight=#000000 border=1>






    <!--






    -->
    參數一 參數二 參數三 參數四




    <INPUT onclick=tbladdrow(items.value);

    type=button value=新增一行 name=insert/>
      





    ***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+"
    ");

    String paramValues[]=request.getParameterValues(paramName);
    for(int i=0; i<=paramValues.length-1; i++)
    {
    out.println(paramName+" ");
    out.println(paramValues[i]+"
    ");}

    }

    //out.println("
    "+name);

    %>



    接受輸入



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

报告相同问题?

悬赏问题

  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制