如何从另一个模型的背面急切加载模型?

时间:2017-03-15 23:12:07

标签: php laravel

希望这应该为我的问题增加一些背景。我有3个型号。

我的构建模型:

public function buildComment(){
    return $this->hasMany('App\buildComment');
}
public function buildQuestion(){
    return $this->belongsTo('App\buildQuestion');
}

我的buildQuestion模型:

public function build(){
        return $this->hasMany('App\Build');
    }

buildComments模型:

public function build(){
    return $this->belongsTo('App\Build');
}

这是我的控制器:

public function viewQuestion(buildQuestion $buildQuestion){
    $builds = Build::with('buildComment')->get();

    return view('pages.questionView',compact('buildQuestion', 'builds'));
}

这是我的观点:

@foreach($buildQuestion->build as $build)
       <ul class="list-group">
           <li class="list-group-item clearfix active">Build suggestion by: {{$build->user->name}}</li>
            <li class="list-group-item clearfix">Processor: <a href="/parts/cpu/{{$build->processor->id}}">{{$build->processor->name}}</a></li>
            <li class="list-group-item clearfix">Graphics Card: <a href="/parts/gpu/{{$build->videoCard->id}}">{{$build->videoCard->name}}</a></li>
            <li class="list-group-item clearfix">RAM: <a href="/parts/memory/{{$build->memory->id}}">{{$build->memory->name}}</a></li>
            <li class="list-group-item clearfix">Motherboard: <a href="/parts/motherboard/{{$build->motherboard->id}}">{{$build->motherboard->name}}</a></li>
            <li class="list-group-item clearfix">Power Supply: <a href="/parts/power-supply/{{$build->powerSupply->id}}">{{$build->powerSupply->name}}</a></li>
            <li class="list-group-item clearfix">Storage: <a href="/parts/storage/{{$build->storage->id}}">{{$build->storage->name}}</a></li>
            <li class="list-group-item clearfix">Optical Drive: <a href="/parts/optical-drive/{{$build->opticalDrive->id}}">{{$build->opticalDrive->name}}</a></li>
            <li class="list-group-item clearfix"><strong>Build Total Price: £{{$build->processor->price + $build->videoCard->price + $build->memory->price + $build->motherboard->price + $build->powerSupply->price + $build->storage->price + $build->opticalDrive->price}}</strong></li>
        </ul>
        @foreach($build->buildComment as $comment)
        {{$comment->body}}
        @endforeach
        <form action="/build-comment/post/{{$build->id}}" method="POST">
            <div class="form-group">
                <label for="body">Comment </label>
                <textarea class="form-control"  name="body"></textarea>
            </div>
            <input type="hidden" name="_token" value="{{ csrf_token() }}">
            <button type="submit" class="btn btn-primary">Submit</button>
        </form>
        @endforeach

我正在尝试获取属于构建的评论。

buildQuestion有很多构建,构建有很多注释。

如何表示并检索构建的注释?

2 个答案:

答案 0 :(得分:1)

您可以使用嵌套的预先加载来在一个查询中获取它们。

//one buildquestion with all the builds & comments
$buildQuestion = BuildQuestion::with('build.buildComment')->find(1); 

return view('pages.questionView',compact('buildQuestion'));

在你看来,嵌套你的foreach

@foreach($buildQuestion->build as $build)
    //display stuff

    @foreach($build->buildComment as $comment)
         {{ $comment->body}}
    @endforeach
@endforeach

答案 1 :(得分:0)

@foreach($buildQuestion->build as $build)
   <ul class="list-group">
       <li class="list-group-item clearfix active">Build suggestion by: {{$build->user->name}}</li>
        <li class="list-group-item clearfix">Processor: <a href="/parts/cpu/{{$build->processor->id}}">{{$build->processor->name}}</a></li>
        <li class="list-group-item clearfix">Graphics Card: <a href="/parts/gpu/{{$build->videoCard->id}}">{{$build->videoCard->name}}</a></li>
        <li class="list-group-item clearfix">RAM: <a href="/parts/memory/{{$build->memory->id}}">{{$build->memory->name}}</a></li>
        <li class="list-group-item clearfix">Motherboard: <a href="/parts/motherboard/{{$build->motherboard->id}}">{{$build->motherboard->name}}</a></li>
        <li class="list-group-item clearfix">Power Supply: <a href="/parts/power-supply/{{$build->powerSupply->id}}">{{$build->powerSupply->name}}</a></li>
        <li class="list-group-item clearfix">Storage: <a href="/parts/storage/{{$build->storage->id}}">{{$build->storage->name}}</a></li>
        <li class="list-group-item clearfix">Optical Drive: <a href="/parts/optical-drive/{{$build->opticalDrive->id}}">{{$build->opticalDrive->name}}</a></li>
        <li class="list-group-item clearfix"><strong>Build Total Price: £{{$build->processor->price + $build->videoCard->price + $build->memory->price + $build->motherboard->price + $build->powerSupply->price + $build->storage->price + $build->opticalDrive->price}}</strong></li>
    </ul>
    @foreach($build->buildComment as $comment)
    {{$comment->body}}
    @endforeach
    <form action="/build-comment/post/{{$build->id}}" method="POST">
        <div class="form-group">
            <label for="body">Comment </label>
            <textarea class="form-control"  name="body"></textarea>
        </div>
        <input type="hidden" name="_token" value="{{ csrf_token() }}">
        <button type="submit" class="btn btn-primary">Submit</button>
    </form>
    @endforeach

在@EddyTheDove建议进行此更改之后,我嵌套了另一个foreach,并且它有效。