flashr
v1.0.1
这是我有史以来出版的第一个包裹。我想学习如何为Laravel制作一个简单的包裹。我一直在阅读很多有关IOC容器,Laravel的依赖注入等等的信息...此软件包的灵感来自Great Laracasts/Flash套件!
跑步
$ composer require linking/flashr
安装软件包时,如果您正在运行Laravel 5.X,则可以在AppServiceProvider中注册包裹,
<?php
use Linking Flashr FlashrServiceProvider ;
use Illuminate Support ServiceProvider ;
class AppServiceProvider extends ServiceProvider
{
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot ()
{
// ...
$ this -> app -> register (FlashrServiceProvider::class);
}
}如果您正在运行旧版本的Laravel,则可以编辑App.php文件,并将其添加到providers选项中
' providers ' => [
// ...
Linking Flashr FlashrServiceProvider::class,
];您还应该在“ Aliases”密钥下的File App.php中添加外墙
' aliases ' => [
// ..
' Flashr ' => Linking Flashr Facades Flashr::class,
// ..
];在您的控制器中,您可以做
public function edit ( Post $ post ) {
Flashr:: success ( " The post has been edited " );
return view ( ' post.edit ' , compact ( ' post ' ));
}FlashR暴露了不同的功能,以打印不同类型的闪光灯。这是FlashR函数的列表:
Flashr::success($message)Flashr::info($message)Flashr::warning($message)Flashr::danger($message)然后,在您的观点中,您可以通过执行来包括供应商的观点
@include ( ' flashr::flashes ' )注意:默认情况下,它使用Twitter引导符号。如果您想替换此行为,只需阅读下一步
如果您想自定义视图,只需做
php artisan vendor:publish --tag=flashr
然后,去看您的视图目录。您应该找到一个供应商目录。在此目录内, FlashR目录将在这里。您可以将此文件编辑为您想要的任何内容。默认情况下,文件看起来像这样:
@php
$flashr_type = Session :: has ( ' _flashr.type ' ) ? Session :: get ( ' _flashr.type ' ) : null ;
$flashr_message = Session :: has ( ' _flashr.message ' ) ? Session :: get ( ' _flashr.message ' ) : null ;
@endphp
@if ( $flashr_type && $flashr_message )
< div style = " position : relative " class = " alert alert- {{ $flashr_type } } " role = " alert " >
{{ $flashr_message } }
< span id = " close-flash " onclick = " var el = this.parentElement; el.remove() "
style = " position : absolute ; top : 10 px ; right : 10 px ; font-size : 24 px ; line-height : 10 px ; cursor : pointer " > & times ; </ span >
</ div >
@endif如您所见,插件在会话中添加两个键: _flashr.type和_flashr.message