jsp 文本值的读取 插入数据库
大概是这样的 前台页面的table中的tr 用js可以自动添加
(行可以自动加 每行文本name对应相等)
后台读取文本区的值,读取
商品 | 数量 | 单价 | 小计 | 操作 |
在网上找了一下,只有一篇此类文章,还是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页其它代码:
輸入
參數一 | 參數二 | 參數三 | 參數四 |
---|---|---|---|
<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);
%>
接受輸入
[quote]用js可以自动添加[/quote]
[quote]每行文本的name也一样 [/quote]
如果你每行文本的name是一样那就没办法了。只能是你的js在生成的时候自动在文本后面添加一个[n]
例如
name=p[1]
name=p[2]
这样的话你就能从request中如得到一个数组了。
js怎么写就请你google一下了。
在js里设置一个全局变量如:globalindex,name设置成name[globalindex]的形式,每增加一行你就让globalindex++,删除的时候不需要减了,只是删除固定index位置的数据,因为后台可以得到一个list,所以只要globalindex没有重复值就好了
写一个脚本,每添加一行,添加到一个二维数组中(例如A[1][2],表示第一行的第二个字段),这样的话,到时就从这个数组中取值去存就好了.
-_-!
同志……这样去生成,够详细吧....
[code="js"]
var tr = document.createElement("tr");
var td = document.createElement("td");
var genText = document.getElementById("merchant");//你的一个text,这里是id不要搞错了。
var input = genText.cloneNode(true);
input.id="";//你的text的id
input.name = "genTextName["+i+"]";//你的text的名字i就是你的变量
input.value="";//不要说了.........
td.appendChild(input);
tr.appendChild(td);
[/code]