belongsTo(SysBannerModel::class, 'banner_id', 'id'); } // 关联相关产品分类中间表模型 public function prodMapping() { return $this->hasOne(SysBannerProdCateMappingModel::class, 'banner_item_id', 'id'); } // 从产品分类关联模型中获取id字段 public function getRelProdCateIdAttr() { return $this->prodMapping?->category?->id; } // 从产品分类关联模型中获取name字段 public function getRelProdCateNameAttr() { return $this->prodMapping?->category?->name; } // 按横幅标题搜索 public function searchTitleAttr($query, $value, $data) { if (empty($value)) { return; } $query->where('title', 'like', "%{$value}%"); } // 按添加时间搜索 public function searchCreatedAtAttr($query, $value, $data) { if (empty($value)) { return; } if (is_array($value)) { if (count($value) > 1) { $query->whereBetweenTime('created_at', $value[0], $value[1]); } else { $query->whereTime('created_at', '>=', $value[0]); } } } // 根据横幅id查询 public function scopeBannerId($query, $value) { if (is_null($value)) return; if (is_array($value) || str_contains($value, ',')) { $query->whereIn('banner_id', $value); return; } $query->where('banner_id', '=', $value); } }