当前位置 主页 > 网站技术 > 代码类 >

    关于Laravel-admin的基础用法总结和自定义model详解

    栏目:代码类 时间:2019-10-15 21:02

    总结laravel-admin展示用到的基本方法

    基础用法

    自定义model

    当列表数据获取有特定条件或自己写ORM方法时可以用到,支持排序
    $grid->model()->select('id','name')->where('status',1)->groupBy('project_id');
    $grid->model()->select('id','name')->where('status',1)->groupBy('project_id');
    //结合having 查出名字重复的
    $grid->model()->select('name_en')->groupBy('name_en')->havingRaw('count(name_en)>1')
    //嵌套子查询 查出名字重复的全部信息
    $grid->model()->select('id','name_en')->whereIn('name_en',Project::select('name_en')->groupBy('name_en')->havingRaw('count(name_en)>1'))->orderBy('name_en');

    模型数据获取

    第一列显示id字段,并将这一列设置为可排序列

    $grid->id('ID')->sortable();

    获取单列数据的方法

    $grid->name_cn('名称');

    注:name_cn为与数据库对应的字段名

    $grid->column('name_cn','名称');

    判断type来显示不同的状态

    $grid->column('type','类型?')->display(function ($type) {
     return $type == 1 ? '111' : '222';
    });

    where条件

    $grid->model()->where('type', 0);

    三个时间的显示

    // 下面为三个时间字段的列显示
    $grid->release_at();
    $grid->created_at();
    $grid->updated_at();

    筛选框控制方法

    基本方法

     //filter($callback)方法用来设置表格的简单搜索框
     $grid->filter(function ($filter) {
      //1.时间段筛选 设置created_at字段的范围查询
      $filter->between('created_at', '筛选时间')->datetime();
      //2.字段模糊查询 like = '% %'
      $filter->like('name', '姓名');
      //3.字段equal 筛选
      $filter->equal('status', '状态')->select([0 => '下线', 1 => '上线']);
      //4.去掉默认的ID搜索
      $filter->disableIdFilter();
      //5.
    
     });
    

    按钮控制

    禁用导出

    $grid->disableExport();

    禁用新增

    $grid->disableCreateButton();

    禁用行选择checkbox

    $grid->disableRowSelector();

    去掉重置 [from]

    $form->disableReset();

    关闭默认行操作

     $grid->actions(function ($actions) {
      //关闭删除
     $actions->disableDelete();
     //关闭编辑
     $actions->disableEdit();
     //自定义操作按钮
     $actions->append('<button type="button" class="btn btn-danger noShow" data- >隐藏</button>');
    });

    关闭批量删除

    $grid->tools(function ($tools) {
     //关闭批量删除
     $tools->batch(function ($batch) {
      $batch->disableDelete();
     });
    });

    FORM表单提交

    禁用重置按钮

     $form->disableReset();

    文本输入框

    //默认展示$data['name']的值,新接收的值存储user表name字段
    $form->text('user.name', '名称')->default($data['name']);