我最近在开发一个博客系统,使用laravel nova作为后台管理界面。为了方便管理文章,我需要为每篇文章生成一个唯一的slug,用于文章的url。起初,我尝试手动维护slug,但很快发现这非常低效。每添加一篇文章,都需要手动检查slug的唯一性,如果重复则需要手动修改,这不仅浪费时间,还容易出错。更糟糕的是,在多人协作的开发环境下,这种手动方式会变得更加混乱。
于是我开始寻找解决方案,最终找到了drobee/nova-sluggable这个laravel Nova扩展包。它可以自动生成唯一的Slug,并在用户输入标题时实时更新,完美地解决了我的问题。
安装drobee/nova-sluggable非常简单,只需要使用composer:
composer require drobee/nova-sluggable
安装完成后,在你的Nova资源中添加SluggableText和Slug字段:
use DrobeeNovaSluggableSluggableText;<br>use DrobeeNovaSluggableSlug;</p><p>class Post extends Resource<br>{</p><pre class="brush:php;toolbar:false">// ... public function fields(Request $request) { return [ // ... SluggableText::make('标题'), Slug::make('Slug'), // ... ]; }
}
就这么简单!现在,当用户在“标题”字段输入文字时,“Slug”字段会自动生成对应的Slug,并且保证其唯一性。 这个包甚至支持自定义Slug字段名称、语言、最大长度、分隔符以及更新事件(keyup或blur)。 例如,要自定义Slug字段的最大长度为100,可以使用如下代码:
Slug::make('Slug')->slugMaxLength(100);
更重要的是,drobee/nova-sluggable可以与流行的SpatieSluggable包无缝集成,如果你的模型已经使用了SpatieSluggable,那么drobee/nova-sluggable会自动继承其配置,无需额外设置。 这大大简化了配置过程,并确保了Slug生成的一致性。
为了确保Slug的唯一性,你需要在Slug字段上调用slugUnique()方法,并指定Eloquent模型:
Slug::make('Slug')</p><pre class="brush:php;toolbar:false">->slugUnique() ->slugModel(static::$model);
通过这些简单的配置,drobee/nova-sluggable 就能够为我的博客系统自动生成唯一且友好的Slug,极大地提升了开发效率和用户体验。 再也不用担心Slug重复或手动维护Slug带来的麻烦了! 这让我可以将更多精力投入到其他更重要的功能开发中。 如果你也正在为Laravel Nova项目的Slug问题苦恼,强烈推荐你试试drobee/nova-sluggable。 相信它会成为你开发利器,让你的开发过程更加流畅高效。 学习更多关于Composer的使用技巧,可以参考这个Composer在线学习地址:学习地址。