结果

代码
<?php
namespace App\Admin\Controllers\Demo;
use App\Models\Tag;
use App\User;
use Encore\Admin\Form;
use Encore\Admin\Grid;
use Encore\Admin\Facades\Admin;
use Encore\Admin\Layout\Content;
use App\Http\Controllers\Controller;
use Encore\Admin\Controllers\ModelForm;
use Encore\Admin\Widgets\Box;
use Encore\Admin\Widgets\Tab;
class TagController extends Controller
{
use ModelForm;
...
protected function grid()
{
return Admin::grid(Tag::class, function (Grid $grid) {
$grid->id('ID')->sortable();
$grid->name()->editable();
$grid->options()->checkbox([
1 => 'Sed ut perspiciatis unde omni',
2 => 'voluptatem accusantium doloremque',
3 => 'dicta sunt explicabo',
4 => 'laudantium, totam rem aperiam',
]);
$states = [
'on' => ['text' => 'YES'],
'off' => ['text' => 'NO'],
];
$grid->column('switch_group')->switchGroup([
'recommend' => '推荐', 'hot' => '热门', 'new' => '最新'
], $states);
$grid->created_at();
$grid->updated_at();
});
}
protected function form()
{
return Admin::form(Tag::class, function (Form $form) {
$form->display('id', 'ID');
$form->text('name')->rules('required');
$form->checkbox('options')->options([
1 => 'Sed ut perspiciatis unde omni',
2 => 'voluptatem accusantium doloremque',
3 => 'dicta sunt explicabo',
4 => 'laudantium, totam rem aperiam',
]);
$form->switch('recommend');
$form->switch('hot');
$form->switch('new');
$form->display('created_at', 'Created At');
$form->display('updated_at', 'Updated At');
});
}
...
}
模型
app/Models/Tag.php
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Model;
class Tag extends Model
{
protected $table = 'demo_tags';
public function setOptionsAttribute($options)
{
if (is_array($options)) {
$this->attributes['options'] = implode(',', $options);
}
}
public function getOptionsAttribute($options)
{
if (is_string($options)) {
return explode(',', $options);
}
return $options;
}
}
表结构
CREATE TABLE `demo_tags` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
`hot` tinyint(1) NOT NULL DEFAULT '0',
`new` tinyint(1) NOT NULL DEFAULT '0',
`recommend` tinyint(1) NOT NULL DEFAULT '0',
`options` varchar(255) COLLATE utf8_unicode_ci NOT NULL DEFAULT '',
`created_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
`updated_at` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci