给你写了个,可以实现你的要求,但感觉不是最好的。就当是抛砖引玉了,哪位朋友有更好的,别忘了贴出来。不知道光是正则能否实现?? <script type="text/javascript"> function CreateFormTemplates(){ var _html=document.getElementById("temp").value; if(_html.length==0){document.getElementById("form").innerHTML='';return} var min=50;//输入框默认的长度 var step=10;//每多一个_,递增的长度 //将非_的全替换成$1 var re=/[^_]/g; var str=_html.replace(re,'$1'); var arr=str.split('$1');
//以_分隔原内容 var arr2=_html.split("_");
//定义$1的真实文本存储数组 var arr3=[]; var newhtml='';//待写入的内容
制作表单模板?
在你处理:并将输入的字符显示在页面中的一个位置 这个操作的时候。顺便处理就可以了,
假定:输入框初始长度设为50;每多一个_,就+10。假如有3个连在一起的_,那总长度就是:50+10*3=80;最后生成输入框时:
<input type="input" style="80px">至于这个递增多少,你自己设置就可以了。大致的思路就是这样了
<input type="input" style="width:80px">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
</head><body>
<input type="text" name="inputName" id="inputId" value=""/>
<input type="button" name="点击提交" id="btnId" />
<div id="xianShi"></div>
<script type="text/javascript">
document.getElementById("btnId").onclick = function() {
var str = document.getElementById("inputId").value;
str=str.replace(/_/g,"<input type=\"text\" name=\"\" id=\"\" value=\"\"/>");
document.getElementById("xianShi").innerHTML = str;
}
</script>
</body>
</html>
测试通过,代码自己优化吧
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
</head><body>
<input type="text" name="inputName" id="inputId" value=""/>
<input type="button" name="点击提交" id="btnId" />
<div id="xianShi"></div>
<script type="text/javascript">
document.getElementById("btnId").onclick = function() {
var str = document.getElementById("inputId").value;
str=str.replace(/_/g,"<input type=\"text\" name=\"\" id=\"\" value=\"\"/>");
document.getElementById("xianShi").innerHTML = str;
}
</script>
</body>
</html>
测试通过,代码自己优化吧
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
</head><body>
<input type="text" name="inputName" id="inputId" value=""/>
<input type="button" name="点击提交" id="btnId" />
<div id="xianShi"></div>
<script type="text/javascript">
document.getElementById("btnId").onclick = function() {
var str = document.getElementById("inputId").value;
str=str.replace(/_/g,"<input type=\"text\" name=\"\" id=\"\" value=\"\"/>");
document.getElementById("xianShi").innerHTML = str;
}
</script>
</body>
</html>
<script type="text/javascript">
function CreateFormTemplates(){
var _html=document.getElementById("temp").value;
if(_html.length==0){document.getElementById("form").innerHTML='';return}
var min=50;//输入框默认的长度
var step=10;//每多一个_,递增的长度
//将非_的全替换成$1
var re=/[^_]/g;
var str=_html.replace(re,'$1');
var arr=str.split('$1');
//以_分隔原内容
var arr2=_html.split("_");
//定义$1的真实文本存储数组
var arr3=[];
var newhtml='';//待写入的内容
//获取$1对应的替换文本:以_分隔后,如果长度大于0的,则是一个文本
for(i=0;i<arr2.length;i++){
if(arr2[i].length>0){
arr3.push(arr2[i]);
}
}
//开始获取写入内容
for(i=0;i<arr.length;i++){
if(arr[i].length>0){
var width=min+step*arr[i].length;
newhtml+='<input type="text" style="width:'+width+'px">';
if(arr3[i]){newhtml+=arr3[i]}
}else{if(arr3[i]){newhtml+=arr3[i]}}
}
document.getElementById("form").innerHTML=newhtml;
}
</script>
<div id="form"></div>
输入框:<input type="text" id="temp" value="" onkeyup="CreateFormTemplates()" />