italofantone/sluggable
最新稳定版本:v2.0.0
Composer 安装命令:
composer require italofantone/sluggable
包简介
Is a PHP library designed to simplify and automate the creation of URL-friendly slugs based on Laravel.
README 文档
README
Is a PHP library designed to simplify and automate the creation of URL-friendly slugs based on Laravel.
⚠️ This code was used for educational purposes [...]
Installation
You can install the sluggable package via composer. Run the following command:
composer require italofantone/sluggable
Usage
- Add the trait to your model:
To use the Sluggable functionality, include the Sluggable trait in your Eloquent model. Here's an example:
<?php
namespace App\Models;
use Italofantone\Sluggable\Sluggable;
use Illuminate\Database\Eloquent\Model;
class Lesson extends Model
{
use Sluggable;
protected $fillable = ['title', 'body'];
}
Migration example: You need to create the slug field.
<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration
{
/**
* Run the migrations.
*/
public function up(): void
{
Schema::create('lessons', function (Blueprint $table) {
$table->id();
$table->string('title');
$table->string('slug')->unique();
$table->text('body');
$table->timestamps();
});
}
/**
* Reverse the migrations.
*/
public function down(): void
{
Schema::dropIfExists('lessons');
}
};
- Customize the separator: Run the following command.
php artisan vendor:publish --tag=sluggable-config
You can customize the slug separator in the config/sluggable.php file. For example:
<?php
return [
/**
* The field that will be used to generate the slug.
* e.g. 'my title' will be converted to 'my-title'.
*
* Default: '-'.
*/
'separator' => '-',
];
This will change the default separator used in generated slugs.
- Customizing the slug source field:
You can customize which attribute is used to generate the slug by setting the protected $slugSourceField property in your model.
Example:
To use the name attribute instead of the default attribute (like title), do the following:
<?php
namespace App\Models;
use Italofantone\Sluggable\Sluggable;
use Illuminate\Database\Eloquent\Model;
class Lesson extends Model
{
use Sluggable;
protected $fillable = ['name', 'body'];
protected $slugSourceField = 'name';
}
With this configuration, the slug will be generated based on the name attribute.
Contact
- Email: i@rimorsoft.com
- Twitter: @italofantone
- LinkedIn: italofantone
Donations
If you find this project useful and would like to support its development, you can make a donation via PayPal:
- PayPal: Donate via PayPal
Thank you for your support!
统计信息
- 总下载量: 255
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 8
- 点击次数: 3
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-04-29