编程语言
首页 > 编程语言> > javascript-使用动态创建的输入字段插入多条记录

javascript-使用动态创建的输入字段插入多条记录

作者:互联网

基本上这就是我在将新记录保存到数据库时使用eloqouent所做的工作(请参阅下文)

$item = new item();
$item->name = $request->name;
$item->description = $request->description;
$item->rating = $request->rating;
$item->save();

但是我遇到了动态创建输入字段的场景,所以这是我的脚本

$(document).on("click", "#create_input", function(){
    $("form fieldset").append('<input type="text" name="name" value="" /><input type="text" name="description" value="" /><input type="text" name="rating" value="" />');
});

而我的默认格式是(请参阅下文)

<button id="#create_input">Create new field</button>
<form action="{{ url('/item/add') }}" method="post">
    <input type="hidden" name="_token" value="{{ csrf_token() }}">
    <fieldset>
        <input type="text" name="name" value="" />
        <input type="text" name="description" value="" />
        <input type="text" name="rating" value="" />
    </fieldset>
    <button>Save</button>
</form>

因此,如果用户单击“创建新字段”按钮,则会将另一个输入字段(名称,描述,等级)添加到表单字段集中.

因此,如何像保存两个记录一样保存它(假设我有两组名称,描述,等级的字段集)?取决于当前表单中存在的字段数,然后取决于插入数,例如我有4个评分,描述,评分字段集,然后将插入4条记录.有什么想法吗?

解决方法:

只需在输入字段的名称旁加上[],例如您的表单以及javascript click事件处理程序中的name =“ discription []”.

然后在保存部分中使用循环

$c = count($request->name[]);
for($i=0;$i<$c;$i++){
   $item = new item();
   $item->name = $request->name[$i];
   $item->description = $request->description[$i];
   $item->rating = $request->rating[$i];
   $item->save();
}

标签:laravel,laravel-5,javascript,php,jquery
来源: https://codeday.me/bug/20191119/2037583.html