假设我有一个名为Car and Image的模型。汽车有多个图像,所以我可以使用以下
public function images()
{
return $this->hasMany('App\Image')->orderBy('order', 'asc');
}
当我想要显示图库时哪个好。但是,假设我想要他们的第一张图片,我可以使用这个
public function firstimg()
{
return $this->hasOne('App\Image')->orderBy('order', 'asc')->take(1);
}
哪个也很好用。
现在的问题是:如果汽车没有图像,它将返回NULL。相反,我希望它返回一些默认的图像对象,因为我想避免在视图中检查它。这在很多地方使用,这就是为什么我想在模型中而不是在控制器或视图中实现它。 如何在不做太多SQL查询的情况下做到这一点?
答案 0 :(得分:0)
您可以在模型中创建一个函数,以便在存在时返回汽车图像,或者使用默认图像路径返回默认图像对象,如下面的示例函数
function getCarImages(){
if( $this->has('images', '>=', 1) ) {
return $this->images;
}else{
$img = new App\Image;
$img->url = 'path/to/default/image.jpg';
return $img;
}
}
我认为你的功能应该是那样的
function firstimg(){
if( $this->has('images', '>=', 1) ) {
return $this->images->first();
}else{
$img = new App\Image;
$img->url = 'path/to/default/image.jpg';
return $img;
}
}
希望这对你有所帮助。