首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >外观\点火\异常\视图异常缺少[路由: trainingcategories.update]所需的参数

外观\点火\异常\视图异常缺少[路由: trainingcategories.update]所需的参数
EN

Stack Overflow用户
提问于 2020-01-24 08:38:22
回答 3查看 1.9K关注 0票数 1

可以seam找出问题是模型没有返回任何数据,我已经检查了控制器,视图,路由和一切似乎都是正常的。

代码语言:javascript
复制
    public function edit(TrainingCategory $trainingCategory)
    {
        return view('admin.trainingcategories.edit')->with(['trainingcategory'=>$trainingCategory]);
    }

这是我的控制器方法,$trainingCategory不从数据库返回所需的数据。

代码语言:javascript
复制
Route::prefix('admin')->middleware('is_admin')->group(function () {
    Route::get('/dashboard', 'HomeController@adminHome')->name('admin.home');
    Route::resource('positions', 'PositionsController');
    Route::resource('departments', 'DepartmentsController');
    Route::resource('trainings', 'TrainingsController');
    Route::resource('trainingcategories', 'TrainingCategoriesController');
    Route::get('/trainingcategories/{id}/{action}', 'TrainingCategoriesController@changestatus')->name('trainingcategories.status');
});

以下是我的路径文件,其中显示了代码

代码语言:javascript
复制
@extends('layouts.admin')
@section('content')
<div class="app-main__inner">
    <div class="app-page-title">
        <div class="page-title-wrapper">
            <div class="page-title-heading">
                <div class="page-title-icon">
                    <i class="pe-7s-user icon-gradient bg-mean-fruit">
                    </i>
                </div>
                <div>Edit Training Category
                    <div class="page-title-subheading">Modify.
                    </div>
                </div> 
            </div>
            <div class="page-title-actions">

                <div class="d-inline-block dropdown">
                    <a href="{{ route('trainingcategories.create') }}" type="button"  class="btn-shadow  btn btn-info">

                        Create New Training Category
                        <span class="btn-icon-wrapper pr-2 opacity-7">

                        </span>
                    </a>
                    <a href="{{ route('trainingcategories.index') }}" type="button"  class="btn-shadow  btn btn-primary">

                        List  Training Categories
                        <span class="btn-icon-wrapper pr-2 opacity-7">
                            <i class="fa fa-arrow-right fa-w-20"></i>
                        </span>
                    </a>

                </div>
            </div>
                </div>
    </div>            
   <!--Data table section-->

   <div class="row">
       <div class="col-md-12">

        <nav class="" aria-label="breadcrumb">
            <ol class="breadcrumb">
                <li class="breadcrumb-item"><a href="{{ route('admin.home') }}">Dashboard</a></li>
            <li class="breadcrumb-item"><a href="{{ route('trainingcategories.index') }}">Training Category</a></li>
                <li class="active breadcrumb-item" aria-current="page">Edit Training Category</li>
            </ol>
        </nav>
           <!--alerts-->
           @if(!empty($errors->all()) )

                          <div class="alert alert-danger fade show" role="alert">
                              @foreach ($errors->all() as $error)
                                      <li>{{ $error }}</li>     
                              @endforeach
                          </div>
            @endif
            <!--end alerts--> 
        <div class="main-card mb-3 card">
        <div class="card-body"><h3 class="h4">Edit Training Category > <b>{{ $trainingcategory->name }}</b><br>
                <small class="muted">Modify</small></h3>
                <hr>
                <form class="needs-validation" novalidate method="POST" action="{{ route('trainingcategories.update',['trainingcategory'=>$trainingcategory->id]) }}">
                    @csrf
                    @method('PUT')
                        <div class="department-relative form-group">
                            <label for="name" class="">Name</label>
                                <input name="name" id="name" placeholder="Enter training category" type="text" class="form-control" 
                                value="{{ old('name',$trainingcategory->name) }}" required>
                                <div class="valid-feedback">
                                    Looks good!
                                </div>
                                <div class="invalid-feedback">
                                    Please enter training category.
                                </div>
                            </div>
                        <div class="department-relative form-group">
                            <label for="description" class="">Active<i class="muted"></i></label>
                            @include('includes._active_select')
                            </div>
                        <div class="department-relative form-group">
                            <label for="description" class="">Training Description<i class="muted">(Optional)</i></label>
                            <textarea name="description" id="description" class="form-control" required> {{ old('description',$trainingcategory->description) }} </textarea>
                            <div class="valid-feedback">
                                Looks good!
                            </div>
                            <div class="invalid-feedback">
                                Please enter training description.
                            </div>
                        </div>
                        <button class="mt-1 btn btn-primary">update</button>
                    </form>
                </div>

        </div>
</div>
</div>
     <!-- form validation-->
<script>
// Example starter JavaScript for disabling form submissions if there are invalid fields
(function() {
'use strict';
window.addEventListener('load', function() {
// Fetch all the forms we want to apply custom Bootstrap validation styles to
var forms = document.getElementsByClassName('needs-validation');
// Loop over them and prevent submission
var validation = Array.prototype.filter.call(forms, function(form) {
form.addEventListener('submit', function(event) {
    if (form.checkValidity() === false) {
        event.preventDefault();
        event.stopPropagation();
    }
    form.classList.add('was-validated');
}, false);
});
}, false);
})();
</script>
   <!--end data table section-->


</div>

@endsection

这是我的观点

EN

回答 3

Stack Overflow用户

发布于 2020-01-27 03:35:55

伙计们,我最终通过将变量名trainingCategory更改为$trainingcategory (注意小写的'c',与资源路由命名相匹配).So资源从数据库返回数据,最终解决了这个问题。

Laravel自动解析在变量名称与路线段名称匹配的路线或控制器操作中定义的类型提示模型。

票数 2
EN

Stack Overflow用户

发布于 2020-01-24 08:56:47

该错误与路由: trainingcategories.update相关。当你这样做的时候:

代码语言:javascript
复制
Route::resource('trainingcategories','TrainingCategoriesController');

您将在TrainingCategoriesController的更新方法中生成以下路由:等待$trainingcategories参数的trainingcategories.update。

如下所示:

代码语言:javascript
复制
public function update(TrainingCategory $trainingCategory)

因此,您需要查看update方法。edit方法没有受到惩罚。

票数 0
EN

Stack Overflow用户

发布于 2020-01-24 09:02:06

您已经展示了如何生成路由:

代码语言:javascript
复制
route('trainingcategories.update',['trainingcategory'=>$trainingcategory->id])

您不需要传入关联数组,您可以传入模型。

代码语言:javascript
复制
route('trainingcategories.update', $trainingcategory)

确保$traningcategory实际存在,并且ID属性不为空。Laravel抱怨说它没有获得所需的参数。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59888983

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档