【问题标题】:Laravel retrieved data object in objectLaravel 检索对象中的数据对象
【发布时间】:2016-03-18 08:32:48
【问题描述】:

在我的 ArticleController 我有:

public function index()
    {
        $article= Article::with('ratingAvg')->get();        
        return view('article.index',['article' => $article]);
    }

在我的文章模型中:

public function ratingAvg()
    {
      return $this->hasOne('App\Rating', 'article_id')
        ->selectRaw('article_id AVG(rating) as rating')
        ->groupBy('article_id');
    }

article.index 中:

@foreach ($article as $a)
  <p>{{$a}}</p>
@endforeach

因此,我从数据库中收到以下数据:

{"id":10,"name":"Article1","rating_avg":{"article_id":10,"rating":"4.0"}}

ArticleController 中运行 dd($article); 时,我收到:

Collection {#194 ▼
  #items: array:2 [▼
    0 => Article{#188 ▼
      #table: "articles"
      #connection: null
      #primaryKey: "id"
      #perPage: 15
      +incrementing: true
      +timestamps: true
      #attributes: array:12 [▶]
      #original: array:12 [▶]
      #relations: array:1 [▼
        "ratingAvg" => Rating {#195 ▼
          #table: "ratings"
          #connection: null
          #primaryKey: "id"
          #perPage: 15
          +incrementing: true
          +timestamps: true
          #attributes: array:2 [▼
            "article_id" => 10
            "rating" => "4.0"
          ]
        }
      ]
    }
  ]
}

我的问题是,如何显示 rating_avg 对象中的 rating 值?

【问题讨论】:

  • for循环中dd( $a );的结果是什么?

标签: php json laravel laravel-5 laravel-blade


【解决方案1】:

这里:

$article = Article::with('ratingAvg')->get(); 

您正在急切加载此关系:

public function ratingAvg()

所以你应该以这种方式访问​​视图中的关系:

@foreach ($article as $a)
    <p>{{ $a->ratingAvg->rating }}</p>
@endforeach

【讨论】:

  • 该死,我总是像在回复中一样尝试{{ $a-&gt;rating_avg-&gt;rating}},但没有成功。现在可以使用,非常感谢
  • 它是 ratingAvg 因为急切加载的关系有这个名称:Article::with('ratingAvg')-&gt;get();
猜你喜欢
  • 1970-01-01
  • 2017-03-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-11-22
  • 1970-01-01
  • 2017-06-19
  • 1970-01-01
相关资源
最近更新 更多