首页 > 解决方案 > 如何从数据库填充选择选项 - Spatie 权限包 - Laravel

问题描述

我正在关注这篇文章,为 Spatie/权限调出前端 UI。

文章

我能够理解每个部分,但我无法理解特定部分,

请导航到角色部分,(请搜索“ roles.edit ”,它将直接进入该部分)

在编辑视图中,作者正在使用代码,

<h5><b>Assign Permissions</b></h5>
    @foreach ($permissions as $permission)
        {{Form::checkbox('permissions[]',  $permission->id, $role->permissions ) }}
        {{Form::label($permission->name, ucfirst($permission->name)) }}<br>
    @endforeach

我的理解是表单集合使用第三个参数作为检查字段。

当我运行传递给第三个字段的输出时

{{$role->权限 }}

我得到这种格式的结果

[{"id":1,"name":"Permission","guard_name":"web","created_at":"2019-08-04 05:53:14","updated_at":"2019-08- 04 05:53:14","pivot":{"role_id":9,"permission_id":1}},

我不确定 laravel 集体如何解析结果。

编辑控制器

 public function edit($id) {
        $role = Role::findOrFail($id);
        $permissions = Permission::all();
        return view('roles.edit', compact('role', 'permissions'));
    }

这是我克服这个问题的方法,顺便说一句,我没有使用集体

我的编辑控制器

 public function edit($id)
    {
        $role = Role::find($id);
        $roles_permissions = Role::findByName($role->name)->permissions;
        $permissions = Permission::all();

        return view('admin.userrole.role.edit', compact('role', 'permissions','roles_permissions'));
    }

我的刀片文件

<h4>Assign Permission</h4>
        <div class='form-group'>
            <p>
                Existing Permissions:
                @foreach ($roles_permissions as $item)
                <span class="badge badge-success"> {{$item->name}}</span>
                @endforeach
            </p>
            <p> {{$role->permissions}}</p>
            <select name="permissions[]" id="permissions" multiple class="form-control">
                @foreach ($roles_permissions as $item)
                <option value="{{$item->id}}" selected hidden></option>
                <span class="badge badge-success"> {{$item->name}}</span>
                @endforeach
                <option value="" selected>
                </option>
                @foreach ($permissions as $permission)
                <option value="{{$permission->id}}" checked="{{$role->permissions}}">{!!ucfirst($permission->name)!!}
                </option>
                @endforeach
            </select>
        </div>

我确信这不是实现这一目标的正确方法。请让我知道如何在选择字段中填充权限。

注意:如果提出问题,请评论为什么。这样我就可以改进我的演示文稿。我很感激你的努力。谢谢

标签: phplaravellaravelcollectivelaravel-permission

解决方案


有几个问题应该可以帮助您完成这项工作。LaravelCollective 表单 (HTML) 库非常棒,但也需要一点时间来适应。

控制器端,您当前正在从该行将完整权限对象列表发送回表单:

 $permissions = Permission::all();

或者,正如作者的表单所做的那样,他们只是从特定的$role. 无论哪种方式,缺少的部分是控制器正在将完整的对象发送回表单,这在当前编码时不起作用。select盒子只需要 name和。id

所以控制器应该使用 pluck 只收集这些字段:

 $permissions = Permission::orderBy('name')->pluck('name', 'id');

然后,在您的刀片页面上,权限选项将与选择部分正确对齐:

{{Form::select('permissions[]', $permissions, null, [//classes, placeholder, multiple, etc] ) }}

请注意这里的一些事情 -$permissions第二个参数,而不是第三个。此外,您不需要指定$permission->id,这是通过 Collective 自动完成的form-model-binding。相反,使用 null 它将绑定到user您已绑定到表单的那个。如果您使用表单模型绑定,则可以使用第三个参数自己编写它,而不是null

 {{Form::select('permissions[]', $permissions, (isset($user->permission_id)? $user->permission_id: [null=>'Please Select']), [//classes, placeholder, multiple etc] ) }}

表单模型绑定非常棒,并且允许您null像上面一样使用......这并不难 - 您只需要使用正确的模型打开表单。这超出了这个问题的范围,但请查看集体文档以获取有关如何执行此操作的示例。


推荐阅读