定制 hamzaejaz/laravel-searchable-scope 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

hamzaejaz/laravel-searchable-scope

最新稳定版本:v1.0.2

Composer 安装命令:

composer require hamzaejaz/laravel-searchable-scope

包简介

A Laravel trait to add dynamic search to models

README 文档

README

A powerful and flexible search trait for Laravel Eloquent models that makes implementing search functionality a breeze.

Features

  • Simple and intuitive API
  • Configurable search behavior
  • Support for related model searching
  • Case-sensitive/insensitive search options
  • Multiple search operators support
  • Minimum search term length configuration
  • Default search columns configuration

Installation

You can install the package via composer:

composer require hamzaejaz/laravel-searchable-scope

The package will automatically register its service provider.

Configuration

Publish the configuration file:

php artisan vendor:publish --provider="HamzaEjaz\SearchableScope\SearchableScopeServiceProvider" --tag="config"

This will create a config/searchable-scope.php file where you can modify the default settings.

Usage

Basic Usage

Add the trait to your model:

use HamzaEjaz\SearchableScope\Traits\Searchable;

class User extends Model
{
    use Searchable;
}

Then you can search like this:

// Search in all default columns
User::search('john')->get();

// Search in specific columns
User::search('john', ['name', 'email'])->get();

// Search in related models
User::search('john', [], ['posts' => ['title', 'content']])->get();

Advanced Usage

You can define default searchable columns and relations in your model:

class User extends Model
{
    use Searchable;

    protected $searchable = [
        'columns' => ['name', 'email', 'username'],
        'relations' => [
            'posts' => ['title', 'content'],
            'profile' => ['bio', 'location']
        ]
    ];
}

Now you can simply call:

User::search('john')->get();

Configuration Options

The package comes with several configuration options in config/searchable-scope.php:

  • default_operator: The default search operator (LIKE, =, >, <, >=, <=)
  • case_sensitive: Whether the search should be case sensitive
  • default_columns: Default columns to search if none specified
  • min_term_length: Minimum length of search term before search is performed

Contributing

Please see CONTRIBUTING.md for details.

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 2.99k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 2
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-04