从Laravel中的动态下拉列表获取ID以在CRUD控制器中使用

时间:2019-10-20 09:36:03

标签: php laravel laravel-blade

我正在使用CRUD控制器,试图创建一个人。 一个人属于一个国家,我已经正确建立了这种关系。

在创建视图中,我具有用于用户输入的文本框,以及通过查询“国家/地区”表而创建的动态下拉菜单。

我的错误是我要创建一个人时遇到错误-常规错误:1364字段“ country_id”没有默认值。

我知道这是因为我没有在country_id中插入任何内容,因为我根本不知道如何从“国家/地区”动态下拉列表中获取ID。

在我的create.blade.php中,我有:

    {{csrf_field()}}
    {{method_field('POST')}}
    <div>
    <input type="text" name="name" placeholder="Name"> <br>
    <input type="text" name="age" placeholder="Age"> <br>
    <input type="text" name="role" placeholder="Role"> <br>
    <input type="text" name="batting" placeholder="Batting"> <br>
    <input type="text" name="bowling" placeholder="Bowling"> <br>
    <input type="text" name="odiRuns" placeholder="Odi Runs"> <br>
    <input type="text" name="image" placeholder="Image name"> <br>
    <label>Select a country:</label>
                <select name="country" class="form-control" style="width:350px">
                    <option value="">--- Select Country ---</option>
                    @foreach ($countries as $country => $value)
                        <option value="{{ $country }}">{{ $value->name }}</option>
                    @endforeach
                </select>
    </div>
    <button type="submit" class="button">Create a player</button>
    </div>
    </form>

在我的控制器中,我有-

        $players = new Player();

        $players->name = request('name');
        $players->age = request('age');
        $players->role = request('role');
        $players->batting = request('batting');
        $players->bowling = request('bowling');
        $players->odiRuns = request('odiRuns');
        $players->image = request('image');
        $players->country_id = request('???');

        $players->save();

有人知道我如何从动态下拉列表中获取country_id值吗?谢谢

1 个答案:

答案 0 :(得分:1)

应该不是$players->country_id = request('country');,因为选择选项的名称是国家/地区