1.动态表单의 화면, 从csdn论坛上参考
<html>
<머리>
<title>无标题文档</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<스크립트 언어="자바스크립트">
var curRow=null;
var y=1;
함수 selectRow(){
var e=window.event;
var tr1=e.srcElement;
if(curRow)
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;
var i=4;
동안(i--){
var newcell = newrow.insertCell();
스위치(i){
사례 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;
동안(i--){
if(src==tab.rows[i]){
//alert("就是这行----"+ i);
document.all.count.value=j-3;
tab.deleteRow(i);
}
}
}
</script>
</head>
<본문>
<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" cellpacing="1" style="border-collapse:collapse" bordercolor="#111111">
<tr>
<th range="col" width="25%">제품명</th>
<th range="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>
</table>
<input type="hidden" name="count" value="count">
<input type="submit" id="btnSub" name="btnSub" value="提交"><br>
</form>
<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%; background-color:#FFFFEF" 값 ="11"></div>
</body>
<div id="div3" style="display:none "><select name="id2" style="width:97%; background-color:#FFFFEF" >
<옵션 값="箱">箱</option>
<옵션 값="件">件</option>
</select></div>
<div id="div4" style="display:none "><input id="txt" type="text" name="id3" style="width:97%; background-color:#FFFFEF" value=" 33"></div>
<스크립트 언어="자바스크립트">
함수 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)
{
모두 유효 = 거짓;
부서지다;
}
모두번호 += ch;
}
if (!allValid)
{
반환(거짓);
}
반환(참);
}
</script>
</html>
2. 2.asp문서
<%
'////////////////////取表单数据
response.write("共"+request.form("count")+"记录")
i=request.form("개수")
jxname=request.form("jxname")
jxadd=request.form("jxadd")
jxtel=request.form("jxtel")
response.write(request.form("jxname"))
response.write("<br>")
response.write(request.form("jxadd"))
response.write("<br>")
response.write(request.form("jxtel"))
response.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)까지
응답."<LI>" & arrayc(i)&"--"&arrayb(i)&"--"&arrayA(i) 쓰기
다음
'///////////////////写入xml文件
희미한 객체
희미한 객체 루트
희미한 objChild1
희미한 objChild2
희미한 objChild3
희미한 objChild4
희미한 objPI
희미한 PINode
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)까지
ObjField = objDom.createElement("field")
'创建属性taborder를 설정합니다.
Set objattTabOrder = objDom.createAttribute("taborder")
'설정된 taborder의 속성값
objattTabOrder.Text = i
'taborder의 속성을 사용하여 필드를 중앙으로 이동합니다.
objField.setAttributeNode objattTabOrder
'는 새로운 元素field_value입니다.
objFieldValue2= objDom.createElement("이름") 설정
objFieldValue2.Text = 배열c(i)
objFieldValue = objDom.createElement("guige") 설정
objFieldValue.Text = arrayb(i)
objFieldValue1=objDom.createElement("shuliang") 설정
objFieldValue1.Text = 배열A(i)
'追加field 모토는 根 元素의 子 모토입니다.
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 = 없음으로 설정
objatID = 없음 설정
objattTabOrder = 없음 설정
objPI = 없음 설정
PINode=아무것도 설정하지 않음
%>
3. 용xsl显示提交적xml,list.xsl
<?xml version="1.0" 인코딩="gb2312" ?>
<xsl:stylesheet version="1.0" xmlns:xsl=" http://www.w3.org/1999/XSL/Transform ">
<xsl:template match="/">
<html>
<body style="배경:#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:apply-templates>
</table></left>
</body>
</html>
</xsl:템플릿>
<xsl:템플릿 일치="kucun">
<tr>
<td width="60%"><div align="center">이름</div></td>
<td width="20%"><div align="center">표시</div></td>
<td width="20%"><div align="center">수량</div></td>
</tr>
<xsl:for-each 선택="필드">
<tr>
<td><xsl:value-of select="이름"/></td>
<td><xsl:value-of select="guige"/></td>
<td><xsl:value-of select="shuliang"/></td>
</tr>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
感谢http://lucky.diy.myrice.com/index.html技术支持