Laravel-在数据库中存储多个复选框表单值

Gro*_*tru 2 html javascript php laravel laravel-5

所以我有这个代码

视图:

<div id="checkboxes">
                         <input type="checkbox" class="checkbox" name="services" value="{{ $service->id }}" id="{{ $service->id }}" />
                         <label class="whatever" for="{{ $service->id }}"><p class="serv-text"> {{ $service->service_name }} + ${{ $service->price }} </p></label>
                             </div>
Run Code Online (Sandbox Code Playgroud)

控制器:

  public function store(Request $request)
    {
       orders::create(Request::all());
        return 'test';
    }
Run Code Online (Sandbox Code Playgroud)

模型:

class orders extends Model
{
    protected $fillable = [
    'category', 
    'services',
    'total_price',
    'user_id',
    'status',
    'user_id'];
}
Run Code Online (Sandbox Code Playgroud)

当我尝试提交表单时,即使在提交表单时选中了多个复选框,在服务数据库中也只有一个数字。我试图在谷歌上找到解决方案,但一无所获。

Luk*_*sák 8

如果您有多个这样的复选框:

<input type="checkbox" name="services" value="1"/>
<input type="checkbox" name="services" value="2"/>
<input type="checkbox" name="services" value="3"/>
Run Code Online (Sandbox Code Playgroud)

它将仅向服务器发送一个值,因为名称必须唯一。解决方法是使用数组输入:

<input type="checkbox" name="services[]" value="1"/>
<input type="checkbox" name="services[]" value="2"/>
<input type="checkbox" name="services[]" value="3"/>
Run Code Online (Sandbox Code Playgroud)

然后,您可以在控制器中获取该输入并执行以下操作:

$services = $request->input('services');
foreach($services as $service){
 orders::create($service);
}
Run Code Online (Sandbox Code Playgroud)

在Laravel中验证数组:

https://laravel.com/docs/5.7/validation#validating-arrays

有关输入数组的更多信息:

https://developer.mozilla.org/zh-CN/docs/Web/HTML/Element/input/checkbox#Handling_multiple_checkboxes

如何将表单输入数组转换为PHP数组