Laravel显示2个表中的数据

时间:2016-04-07 11:33:28

标签: php mysql laravel

让我先解释一下情况。

我在页面上有可用的技能列表,例如" Plumber"," Carpenter"和#34;画家",当我点击其中一项技能时,我想得到一份具有该技能的杂工列表,一旦点击了一个勤杂工,我就会得到关于他的全部细节。

但是当我点击其中一项不想要检索任何数据的技能时,会显示技能。两张桌子" handymen"和#34;技能"有多对多的关系,还有一个联结表。我在这里做错了什么?

Route::group(['middleware' => ['web']], function () {

    Route::get('home', 'HandymanController@home');

    Route::get('search', 'HandymanController@search');

    Route::get('details/{handyman}', 'HandymanController@details');

    Route::post('assignjob', 'HandymanController@assignJob');

    Route::get('addjob', 'HandymanController@addJob');

    Route::post('addjform', 'HandymanController@addjForm');

    Route::get('jobs', 'HandymanController@jobs');

    Route::get('jobsdetails/{jobId}', 'HandymanController@jobsdetails');

    Route::get('deletejob', 'HandymanController@deleteJob');

    Route::post('deletejform', 'HandymanController@deletejForm');

添加工作视图:

@extends('layouts.master')

@section('title', 'Add Job')
        @section('header2')
            <ul>
                <li><a href="{{url('assignjob')}}">Assign job</a></li>
            </ul>
        @show
@section('content')
    <h1>Handyman details</h1>
    <ul>
      @foreach ($handymen as $handyman)
   <a href= "{{ url("HandymanController@details", $handyman->id) }}">
      {{$handyman->name}}
   </a>
@endforeach
    </ul>

控制器:

    function search()
    {
        $skills = Skill::all();
        return view('layouts/search',['skills' => $skills]);
    }
function details($skillId)
{
    $skill = Skill::find($skillId);
    $handymen = $skill->handymen;
    return view('layouts/details', ['handymen' => $handymen]);
}

1 个答案:

答案 0 :(得分:1)

根据您编辑的问题,首先列出搜索视图中的所有技能。因此,在您的搜索视图中,您将拥有以下内容:

@foreach ($skills as $skill)
   <a href= "{{ action("HandymanController@addjForm", $skill->id) }}">
      {{ $skill->name }}
   </a>
@endforeach

所以你必须在你的路线文件中定义这条路线:

Route::post('addjform/{skill}', 'HandymanController@addjForm');

这将指向Handyman Controller,您将列出所有具备该技能的杂工:

public function addjForm(Request $request, Skill $skill)
{
   $handymen = $skill->handymen;
   return view('layouts/skilledHandymen', ['skill' => $skill,'handymen' => $handymen]);
}

为此,您必须在技能模型中定义关联:

public function handymen()
{
    return $this->belongsToMany(Handyman::class,
                            'handyman_skill',
                            'skill_id',
                            'handyman_id');
}

控制器将指向一个视图,您将列出具有此类技能的所有杂工:

在您的情况下,如果您在Skill模型中定义链接到Handyman的关联会更容易:

@foreach ($handymen as $handyman)
   <a href= "{{ action("HandymanController@details", $handyman->id) }}">
      {{ $handyman->name }}
   </a>
@endforeach

当你选择一个勤杂工时,它会带你进入Handyman控制器细节:

function details(Request $request, Handyman $handyman)
{
    return view('layouts/details', ['handymen' => $handymen]);
}

为此您将定义此路线:

Route::get('/handyman/{handyman}', 'Handyman@details');

这将使您最终了解所选勤杂工的细节,并且您可以展示他的详细信息:

<p>{{ $handyman->id }}<p>
<p>{{ $handyman->name }}</p>

在这里要理解的重要事项是,您将首先获得一系列技能,这些技能将引导您进入杂工收藏,而不仅仅是一个。从第二个列表中选择一个杂工后,您将能够显示他的详细信息。如果您尝试跳过此步骤,则会尝试显示列表的详细信息。

希望这会有所帮助......