Laravel表单:允许用户一次添加多个产品

时间:2016-06-10 17:03:22

标签: php laravel laravel-5.2

我有一个表单,用户必须从下拉列表中选择产品并输入使用的数量。我希望用户能够一次添加多个产品。我需要帮助来处理这些数据。

到目前为止,我已经这样做了。我保留了6对字段,用户必须填写第一个,但其他字段是可选的,这是刀片代码。

{!! Form::open(['route' => 'parts.raw.store', 'id' => 'raw-part-form' , 'class'=>'raw-part-form','name'=>'raw-part-form' ]) !!}
@for($in=0;$in<6;$in++)
    <div class='col-md-7'>
        <label for="raw_material_id"{{$in}}>Packing Material</label>
        {!!  Form::select('raw_material_id'.$in, $raw_materials
              ->lists('display_name','id')->prepend('',''),null,
              ['class' => 'form-control', 'id' => 'raw_material_id'.$in])!!}
     </div>
     <div class='col-md-5'>
          <label for="qty_used{{$in}}">Qty used</label>
          <input type="number" min="1" step="1" class="form-control"
          id="qty_used{{$in}}" name="qty_used{{$in}}" placeholder="Qty Used"">
     </div>
@endfor

enter image description here

我不确定这是不是一个好方法。我也很困惑如何在控制器中处理它。

1 个答案:

答案 0 :(得分:3)

类似的东西:

对于刀片:

            @foreach ($foods as $k => $food) // or 1 to 6
            <tr>
              <td>
                <input type="number" name="item[{{$k}}][qty]" value="0">
                <input type="hidden" name="item[{{$k}}][id]" value="{{$food->id}}">
              </td>
              <td>{{ $food->name }}</td>
              <td>{{ $food->price }} €</td>

              <td>
                <a href="/cart/add/{{$food->id}}">+</a>
              </td>
            </tr>
            @endforeach

控制器:

public function checkout(Request $request)
{
  $input = $request->all();

  foreach ($input['item'] as $item) {
    $this->ValidQtyCheck($item['qty']); // >0 or remove it
    $food = Food::findOrFail($item['id'])->toArray();
    Cart::add($item['id'], $food['name'], $item['qty'], $food['price']);
  }

  return redirect('/cart/view');
}

专业提示,对于dinamic添加而不是6总是:pro tip

  

验证数组

     

验证数组表单输入字段并不是一件痛苦的事。对于   例如,验证给定数组输入字段中的每个电子邮件是否为   独特的,您可以执行以下操作:

$validator = Validator::make($request->all(), [
    'person.*.email' => 'email|unique:users',
    'person.*.first_name' => 'required_with:person.*.last_name',
]);

Validating Arrays