我正在创建一个表单,允许用户提供他们所在的其他地址。我有一个下拉菜单,询问“你有多少个额外的地方?”根据他们选择的数字我克隆字段“地址,城市,州,邮编”,并将它们直接放在同一表格内的彼此之下。
我上面描述的是有效但现在我正在尝试从我添加的这些附加字段中检索数据。当用户单击“提交”按钮时,表单将提交到我在其中监听PHP的同一页面,以查看表单是否已提交。如果已经提交,我将表格的值回显到屏幕上。
现在问题就在于此。如果我单独留下Dropbox以使其处于默认值“1”,请填写表单并单击“提交”,我会看到我输入的内容。但是,如果我从下拉列表中选择任何其他值并从所有表单中提交信息,我只会看到最后一个表单中的信息,而不是所有表单中的信息。为什么是这样?我在下面提供了我的代码。
以下是表格:
<form id="blah" method="post">
<div class="Page" id="AdditionalLocations">
<fieldset name="first" class="additional">
<legend>Additional Locations</legend>
<p><label for="Address">Address</label> <input name="Address" type="text" id="Address" /><br /></p>
<p><label for="City">City</label> <input type="text" name="City" id="City" /></p>
<p>
<label for="State">State</label>
<select id="State" name="State">
<option selected="selected">Select your state...</option>
<?php foreach($states as $key=>$value) { ?>
<option value="<?php echo $key; ?>"><?php echo $value; ?></option>
<?php } ?>
</select>
</p>
<p><label for="Zip">Zip Code</label><input type="text" name="Zip" maxlength="6" /></p>
<p><label for="Country">Country</label><select id="Country" name="Country">
<option value="US" selected="selected">United States</option>
<option value="CA">Canada</option>
</select></p>
<input type="submit" value="SUBMIT FORM" />
</fieldset>
</div>
</form>
这是根据下拉列表创建字段的方式
var cloneIndex = 0,
cloneObj = $('.additional').eq(0);
$(document).on('change', "#NumberOfLocations", function() {
if ( $(this).val() !== "" ) {
for( var x = 2; x < $(this).val(); x++ ) {
$('#AdditionalLocations').append( cloneObj.clone( true ).attr('' ,'data-index', ++cloneIndex) )
}
}
});
这是我回应表单结果的方式。如果我不根据下拉菜单创建新的附加字段,它可以工作。
<?php
if($_SERVER['REQUEST_METHOD'] == "POST") {
var_dump($_POST);
foreach( $_POST as $field ) {
if( is_array( $field ) ) {
foreach( $field as $field2 ) {
echo $field2;
}
} else {
echo $field2;
}
}
}
?>
如果我选择2作为位置数字段中的值,则这是我获得的html输出:
<form id="blah" method="post">
<div class="Page" id="AdditionalLocations">
<fieldset name="first" class="additional"></fieldset>
<fieldset name="first" class="additional" data-index="1"></fieldset>
</div>
</form>
在fieldset内部,所有字段都相同。当我点击提交时,为什么我没有回复两个字段集?
更新 所以我通过在chrome检查器内部的末尾添加“1”来更改第二个字段集的名称,现在提交我看到了我需要的所有值。所以我想表单中的每个字段都必须有一个唯一的名称。
答案 0 :(得分:2)
您的字段名称应在其名称末尾带有数组表示法:
<input type="text" name="City[]" id="City" />
<select id="State" name="State[]">
当php获取这些值时,它们将在数组中,因此您需要遍历每个数组以获取信息
for($i=0; $i<count($_POST['City']); $i++){
$city = $_POST['City'][$i];
$state = $_POST['State'][$i];
...
}
可能有更好的方法从数组中获取信息,但这很快且很脏