1.动态表单的界面,来自csdn论坛上参考
<html>
<头>
<title>无标题文档</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<脚本语言=“javascript”>
var curRow=null;
var y=1;
函数选择行(){
var e=window.event;
var tr1=e.srcElement;
if(当前行)
curRow.bgColor="#FFFFFF";
tr1.bgColor="e7e7e7";
当前行=tr1;
}
函数addRow(src){
//警报(src);
var newrow = src.insertRow(src.rows.length-1);
newrow.attachEvent("onclick",selectRow);
newrow.height=20;
变量 i = 4;
而(我--){
var newcell = newrow.insertCell();
开关(一){
case 0: newcell.innerHTML= '<input type="button" onClick="javascript:delRow(this.parentElement.parentElement)" value="删除此行">'+(y++);
document.all.count.value=y-1;
休息;
情况1:newcell.innerHTML=div2.innerHTML;break;
情况2:newcell.innerHTML=div3.innerHTML;break;
情况3:newcell.innerHTML=div4.innerHTML;break;
默认值:newcell.innerHTML=div1.innerHTML;break;
}
}
//警报(newrow.outerHTML);
}
函数 delRow(src){
var tab=src.parentElement;
var i=tab.rows.length;
var j=tab.rows.length;
而(我--){
if(src==tab.rows[i]){
//alert("就是这行----"+ i);
document.all.count.value=j-3;
tab.deleteRow(i);
}
}
}
</脚本>
</头>
<正文>
<form name="form1" action="2.asp" method="post" onsubmit=return(checkv())>
<h3>请输入经销商的通讯信息:</h3>
姓氏:<input type="text" name="jxname"><br>
地址: <input type="text" name="jxadd"><br>
电话: <input type="text" name="jxtel"><br>
请输入库存信息<br>
<table id="tb" width="100%" border="1"align="center" cellpadding="1" cellspacing="1" style="border-collapse:collapse" bordercolor="#111111">
<tr>
<thscope="col" width="25%">品名</th>
<thscope="col" width="25%">规格</th>
<thscope="col" width="25%">库存量</th>
<thscope="col" width="25%">操作</th>
</tr>
<tr id="blankRow" onClick="addRow(this.parentElement)">
<td> </td>
<td> </td>
<td> </td>
<td> </td>
</tr>
</表>
<输入类型=“隐藏”名称=“计数”值=“计数”>
<input type="submit" id="btnSub" name="btnSub" value="提交"><br>
</形式>
<div id="div1" style="display:none"><input id="txt" type="text" name="id" style="width:97%; background-color:#FFFFEF"></ div>
<div id="div2" style="display:none "><input id="txt" type="text" name="id1" style="width:97%; 背景颜色:#FFFFEF" 值=“11”></div>
</正文>
<div id="div3" style="display:none"><select name="id2" style="width:97%; 背景颜色:#FFFFEF">
<选项值=“箱”>箱</选项>
<选项值=“件”>件</选项>
</选择></div>
<div id="div4" style="display:none "><input id="txt" type="text" name="id3" style="width:97%; 背景颜色:#FFFFEF" value=" 33"></div>
<脚本语言=“javascript”>
函数 checkv()
{
if (form1.jxname.value.length == 0)
{
alert("请填写姓名和地址!");
form1.jxname.focus();
返回假;
}
else if(!(check_number(form1.id1.value)))
{
alert("数量只能为数字")
form1.id1.focus();
返回假;
}
别的
返回(真);
}
函数 check_number(myint)
{
var checkOK = "0123456789";
var checkStr = myint;
var allValid = true;
var decPoints = 0;
var allNum = "";
for (i = 0; i < checkStr.length; i++)
{
ch = checkStr.charAt(i);
for (j = 0; j < checkOK.length; j++)
if (ch == checkOK.charAt(j))
休息;
if (j == checkOK.length)
{
所有有效=假;
休息;
}
allNum += ch;
}
if (!allValid)
{
返回(假);
}
返回(真);
}
</脚本>
</html>
2. 2.asp文件
<%
'////////////////////取表单数据
response.write("共"+request.form("count")+"记录")
i=request.form("计数")
jxname=request.form("jxname")
jxadd=request.form("jxadd")
jxtel=request.form("jxtel")
响应.write(请求.form(“jxname”))
响应.write("<br>")
响应.write(请求.form(“jxadd”))
响应.write("<br>")
响应.write(请求.form(“jxtel”))
响应.write("<br>")
str1=trim(request.form("id1"))
str2=trim(request.form("id2"))
str3=trim(request.form("id3"))
arrayA=分割(str1,",")
arrayb=分割(str2,",")
arrayc=Split(str3,",")
对于 i = 0 到 UBound(arrayA)
Response.Write "<LI>" & arrayc(i)&"--"&arrayb(i)&"--"&arrayA(i)
下一个
'///////////////////写入xml文件
昏暗的对象Dom
调暗 objRoot
调暗 objChild1
调暗 objChild2
调暗 objChild3
昏暗的 objChild4
调暗 objPI
暗淡 PI 节点
设置 objDom = Server.CreateObject("Microsoft.XMLDOM")
'///// 书写样式
设置 PINode=objDom.CreateProcessingInstruction("xml-stylesheet", "type='text/xsl'
href='list.xsl'")
objDom.appendchild PINode
'/////创建根接点
设置 objRoot = objDom.createElement("kucunbiao")
objDom.appendChild objRoot
设置 objChild1 = objDom.createElement("jxname")
objChild1.text=jxname
objRoot.appendChild objChild1
设置 objChild2 = objDom.createElement("jxadd")
objchild2.text=jxadd
objRoot.appendChild objChild2
设置 objChild3=objDom.createElement("jxtel")
objChild3.text=jxtel
objRoot.appendChild objChild3
设置 objChild4=objDom.createElement("kucun")
objRoot.appendChild objChild4
对于 i = 0 到 UBound(arrayA)
Set objField = objDom.createElement("field")
'创建属性taborder。
Set objattTabOrder = objDom.createAttribute("taborder")
'设置taborder的属性值
objattTabOrder.Text = i
'把taborder的属性值追加到field元素中去。
objField.setAttributeNode objattTabOrder
'创建一个新的元素field_value。
设置 objFieldValue2= objDom.createElement("name")
objFieldValue2.Text = arrayc(i)
设置 objFieldValue = objDom.createElement("guige")
objFieldValue.Text = arrayb(i)
set objFieldValue1=objDom.createElement("shuliang")
objFieldValue1.Text = arrayA(i)
'追加场元素为根元素的子元素。
objChild4.appendChild objField
'追加field_value做为子元素的内容
objField.appendChild objFieldValue
objField.appendChild objFieldValue1
objField.appendChild objFieldValue2
下一个
设置 objPI = objDom.createProcessingInstruction("xml","version='1.0'")
objDom.insertBefore objPI, objDom.childNodes(0)
objDom.Save "f:xml"&jxname&".xml"
'//////////释放资源
设置 objDom = 无
设置 objRoot = 无
设置 objField = 无
设置 objFieldValue = 无
设置 objattID = 无
设置 objattTabOrder = 无
设置 objPI = 无
设置 PINode=无
%>
3. 使用xsl显示提交的xml,list.xsl
<?xml version="1.0"encoding="gb2312" ?>
<xsl:stylesheet version="1.0" xmlns:xsl=" http://www.w3.org/1999/XSL/Transform ">
<xsl:template match="/">
<html>
<body style="background:#DFEEBB"><左>
<h3>姓名:<xsl:value-of select="kucunbiao/jxname"/></h3>
<h3>地址:<xsl:value-of select="kucunbiao/jxadd"/></h3>
<h3>电话:<xsl:value-of select="kucunbiao/jxtel"/></h3>
<表边框=“1”宽度=“600”>
<xsl:apply-templates select="kucunbiao/kucun" >
</xsl:应用模板>
</table></left>
</正文>
</html>
</xsl:模板>
<xsl:template match="kucun">
<tr>
<td width="60%"><divalign="center">名称</div></td>
<td width="20%"><divalign="center">规格</div></td>
<td width="20%"><divalign="center">数量</div></td>
</tr>
<xsl:for-each select="字段">
<tr>
<td><xsl:value-of select="name"/></td>
<td><xsl:value-of select="guige"/></td>
<td><xsl:value-of select="shuliang"/></td>
</tr>
</xsl:for-each>
</xsl:模板>
</xsl:样式表>
感谢http://lucky.diy.myrice.com/index.html技术支持