![](/img/trans.png)
[英]Need help getting and using user input with HTML form in JavaScript
[英]Need help using datalist input to generate a form
抱歉,以前是否有人问过这个问题,但是我已经运气好几个小时了。
我要完成的工作:我希望有一个表格,该表格首先询问用户他们需要注册多少个孩子(最少1个,最多10个)。 然后,我需要能够使用此变量来使最多10个子项可见。 我打算做的是使用数据列表中的值,然后使用if / else语句生成表单。 (如果id = 2,那么(窗体看起来像这样……)否则)……我不知道该怎么做,就是捕获选择,然后将其传递给if / then语句。
<h2>How many children are you registering?</h2>
<input type="range" value="1" "min=1" max="10" list="number" />
<datalist id="number">
<option>1</option>
<option>2</option>
<option>3</option>
<option>4</option>
<option>5</option>
<option>6</option>
<option>7</option>
<option>8</option>
<option>9</option>
<option>10</option>
</datalist>
HTML:
<h2>How many children are you registering?</h2>
<input type="range" value="1" "min=1" max="10" list="number" onChange="change(this);" />
<datalist id="number">
<option>1</option>
<option>2</option>
<option>3</option>
<option>4</option>
<option>5</option>
<option>6</option>
<option>7</option>
<option>8</option>
<option>9</option>
<option>10</option>
</datalist>
<div id="childrens">
</div>
JAVASCRIPT(在<head>中):
function change(el) {
var container = document.getElementById('childrens'),
child;
// Clear container
container.innerHTML = '';
// Add number of child inputs
for (var i=0; i<el.value; i++) {
child = document.createElement("input");
child.type = 'text';
container.appendChild( child );
}
}
使用jQuery
试试这个。
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<h2>How many children are you registering?</h2>
<input type="range" value="1" "min=1" max="10" list="number" id="list" />
<datalist id="number">
<option value="1">1</option>
<option value="2">2</option>
<option value="3" >3</option>
<option value="4">4</option>
<option value="5">5</option>
<option value="6">6</option>
<option value="7">7</option>
<option value="8">8</option>
<option value="9">9</option>
<option value="10">10</option>
</datalist>
<div id="form_input">
</div>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script type="text/javascript">
$('#list').change(function(){
var i = $(this).val();
var m = 0;
$('#form_input').html("");
if(i != 0){
$('#form_input').append('<form id="form">');
while(m<i){
$('#form_input').append('<input type="text" id="text_'+m+'" name="text_'+m+'" />'); m++;
}
$('#form_input').append('</form>');
}
});
</script>
</body>
</html>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.