我有一个从用户那里收集信息的Laravel表单。在表单的一部分,我想添加一个按钮,该按钮将添加一行,该行包含4个文本框(每个文本框的名称不同),用户可以填写这些文本框。每次用户单击该按钮,都应该添加另一行4个文本盒。
在理想的情况下,代码将是一个单击按钮调用的javascript函数(这样我以后可以重用它)。我似乎看不出如何将事件处理程序添加到laravel表单上的按钮点击中
这很有效HTML
<div class="input_fields_wrap">
<button class="add_field_button">Add More Fields</button>
<div><input type="text" name="mytext[]"></div>
</div>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js"></script>
JS
$(document).ready(function() {
var max_fields = 10; //maximum input boxes allowed
var wrapper = $(".input_fields_wrap"); //Fields wrapper
var add_button = $(".add_field_button"); //Add button ID
var x = 1; //initlal text box count
$(add_button).click(function(e){ //on add input button click
e.preventDefault();
if(x < max_fields){ //max input box allowed
x++; //text box increment
$("#rm").remove();
$(wrapper).append('<div id="divs"><input type="text" name="mytext[]"/>'); //add input box
$(wrapper).append('<div id="divs"><input type="text" name="mytext[]"/>'); //add input box
$(wrapper).append('<div id="divs"><input type="text" name="mytext[]"/></div>'); //add input box
$(wrapper).append('<div id="divs"><input type="text" name="mytext[]"/><a href="#" id="rm" class="remove_field">Remove</a></div>'); //add input box
$(wrapper).append('<br>')
}
});
$(wrapper).on("click",".remove_field", function(e){ //user click on remove text
e.preventDefault(); $("#divs").remove(); x--;
$("#divs").remove(); x--;
$("#divs").remove(); x--;
$("#divs").remove(); x--;
})
});
名称将是mytext(第一个输入名称=mytest[1]
第二个mytest[2]
…等等)您可以将X变量添加到表单中,这样您就可以知道控制器中有多少输入
在html中,您可以将类型更改为隐藏,以便在用户单击之前拥有任何输入字段
检查结果此in JSFiddle