shan016/laravel-autonumber

Laravel 包,用于为 Eloquent 模型创建自增编号

v1.0.0 2024-09-15 12:24 UTC

This package is auto-updated.

Last update: 2024-09-15 13:00:04 UTC


README

Laravel 包,用于为 Eloquent 模型创建自增编号

安装

您可以通过 composer 安装此包

composer require shan016/laravel-autonumber

config/app.php 中注册 ServiceProvider

'providers' => [
    // ...
    Shan016\AutoNumber\AutoNumberServiceProvider::class,
],

发布默认配置

php artisan vendor:publish --provider='Shan016\AutoNumber\AutoNumberServiceProvider'

运行迁移

php artisan migrate

用法

您的 Eloquent 模型应该使用 Shan016\AutoNumber\AutoNumberTrait 特性

特性包含一个抽象方法 getAutoNumberOptions(),您必须自行实现。

use Shan016\AutoNumber\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 许可证

贡献

请在问题页面上报告您发现的问题。欢迎提交拉取请求。