wuwx / laravel-autonumber
Laravel 包,用于为 Eloquent 模型创建自动编号
v4.0.0
2021-03-20 17:51 UTC
Requires
- php: >=5.6.4 || ^7.0 || ^8.0
- illuminate/config: ^6.20|^7.0|^8.0
- illuminate/database: ^6.20|^7.0|^8.0
- illuminate/support: ^6.20|^7.0|^8.0
- laravel/helpers: ^1.0
README
Laravel 包,用于为 Eloquent 模型创建自动编号
安装
您可以通过 composer 安装此包
composer require wuwx/laravel-autonumber
在 config/app.php
中注册 ServiceProvider
'providers' => [ // ... Wuwx\LaravelAutoNumber\AutoNumberServiceProvider::class, ],
发布默认配置
php artisan vendor:publish --provider='Wuwx\LaravelAutoNumber\AutoNumberServiceProvider'
运行迁移
php artisan migrate
使用方法
您的 Eloquent 模型应使用 Wuwx\LaravelAutoNumber\AutoNumberTrait
特性
该特性包含一个抽象方法 getAutoNumberOptions()
,您必须自行实现。
use Wuwx\LaravelAutoNumber\AutoNumberTrait; class Order extends Model { use AutoNumberTrait; /** * Return the autonumber configuration array for this model. * * @return array */ public function getAutoNumberOptions() { return [ 'order_number' => [ 'format' => 'SO.?', // autonumber format. '?' will be replaced with the generated number. 'length' => 5, // The number of digits in an autonumber ], ]; } }
您还可以传递一个 闭包
作为格式值。
public function getAutoNumberOptions() { return [ 'order_number' => [ 'format' => function () { return 'SO/' . date('Ymd') . '/?'; // autonumber format. '?' will be replaced with the generated number. }, 'length' => 5, // The number of digits in the autonumber ], ]; }
保存模型
$order = Order::create([ 'customer' => 'Mr. X', ]);
在保存 Order 模型时,将根据提供的格式自动生成 order_number。
echo $order->order_number; // SO/20170803/00001
许可证
Laravel-autonumber 是开源软件,许可协议为 MIT 协议。
贡献
请在问题页面报告您发现的问题。欢迎提交 pull request。