Laravel 5.5 - 使用 Route::resource 在 URL 中传递变量?



我尝试使用 Laravel 创建一条路径,该路由的路径中有一个变量。 我写道:

Route::resource('/maps/valuechains/{valuechain_id}/segments/', 'BackOfficeSegmentController');

在我的控制器中,我创建了一个索引方法:

public function index(EntityRepository $vcs, $valuechain_id)
{
$entitiesLists = $vcs->getEntities();
$segments = Segment::select()
->join('valuechains', 'segments.valuechain_id', 'valuechains.id')
->join('lang_segment', 'segments.id', 'lang_segment.segment_id')
->join('langs', 'langs.id', 'lang_segment.lang_id')
->join('admins', 'segments.admin_id', 'admins.id')
->where([
['langs.isMainlanguage', '=', 1],
['valuechains.id', '=', $valuechain_id]
])
->get();
$segmentCount = Segment::count();
return view('admin.pages.maps.segments.index', compact('segments', 'segmentCount', 'entitiesLists'));
}

在我看来,我有一个污垢

<span style="overflow: visible; width: 110px;">
<span>
<a href="{{ route('segments.show', $segment->id) }}"
class="m-portlet__nav-link btn m-btn m-btn--hover-accent m-btn--icon m-btn--icon-only m-btn--pill"
title="View details">
<i class="la la-eye"></i>
</a>
<a href="{{ route('segments.edit', $segment->id) }}"
class="m-portlet__nav-link btn m-btn m-btn--hover-accent m-btn--icon m-btn--icon-only m-btn--pill"
title="Edit details">
<i class="la la-edit"></i>
</a>
{!!
Form::open([
'method'    => 'DELETE',
'route'     => ['segments.destroy', $segment->id]
])
!!}
{!!
Form::submit(
' ',
[
'class' => 'la la-trash m-portlet__nav-link btn m-btn m-btn--hover-danger m-btn--icon m-btn--icon-only m-btn--pill',
'title' => 'Delete'
]
)
!!}
{!! form::close() !!}
</span>
</span>

我的问题是以下关于路由名称:

未定义路由 [段.显示]。(查看: C:\wamp64\wwwetwork-dev\resources\views\admin\pages\maps\segments\index.blade.php(

在查看我的路线列表时,我看到这个:

网址如下: 管理员/地图/价值链/{valuechain_id}/段 路由名称为:索引

App\Http\Controllers\BackOffice\SegmentController@index 我应该有段.索引

我只需要删除一个"/",将"段/"替换为我的路由中的"段":

Route::resource('/maps/valuechains/{valuechain_id}/segments/', 'BackOfficeSegmentController');

正确的写作是:

Route::resource('/maps/valuechains/{valuechain_id}/segments', 'BackOfficeSegmentController');

最新更新