belongsTo(ProductCategoryModel::class, 'category_id', 'id'); } // 搜索器名称 public function searchNameNullableAttr($query, $value, $data) { if (is_null($value)) { return; } $query->where('name', 'like', '%' . $value . '%'); } // 搜索spu public function searchSpuNullableAttr($query, $value, $data) { if (is_null($value)) { return; } $query->where('spu', 'like', '%' . $value . '%'); } // 搜索发布时间 public function searchCreatedAtNullableAttr($query, $value, $data) { if (is_array($value)) { if (count($value) == 2) { $query->whereBetweenTime('created_at', $value[0], $value[1]); } else { $query->whereTime('created_at', '>=', $value[0]); } } } // 所属语言查询 public function scopeLanguage($query, $value) { $query->where('language_id', '=', $value); } // 产品分类查询 public function scopeCategoryNullable($query, $value) { if (is_null($value)) { return; } $query->where('category_id', '=', $value); } // 上架状态查询 public function scopeIsShowNullable($query, bool|null $value) { if (is_null($value)) { return; } $query->where('is_show', '=', (int)$value); } }