假设我有一个叫做“汽车与形象”的模型。一辆汽车有多个图像,所以我可以使用以下内容
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查询的情况下执行此操作?
发布于 2015-11-17 12:03:47
您可以在模型中创建一个函数,以便在存在的情况下返回汽车图像,或者返回具有默认图像路径的默认图像对象,如下面的示例函数所示
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;
}
}希望这能帮到你。
https://stackoverflow.com/questions/33752544
复制相似问题