向laravel表单动态添加字段


Add fields to laravel form dynamically

我有一个从用户那里收集信息的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