乌鸦嘴文档 乌鸦嘴文档
乌鸦嘴社区 (opens new window)
乌鸦嘴社区 (opens new window)
  • 入门

  • 数据列表

    • 表格基本使用
    • 列的基本使用
    • 列的显示和扩展
    • 行的使用和扩展
    • 工具栏
    • 树状表格
    • 组合表头
    • 表格数据源
    • 表格关联关系
    • 查询过滤
    • 列过滤器
    • 表格快捷搜索
    • 表格规格筛选器
    • 数据导出
      • 扩展导出功能
    • 快捷创建
    • 数据表格行内编辑
    • 数据表格事件
    • 表格字段翻译
    • 数据软删除
    • 头部和脚部
    • 表格异步渲染
  • 数据表单

  • 数据详情

  • 模型树

  • 数据仓库

  • 动作

  • 多语言

  • 开发扩展

  • 页面组件

  • 区块

  • 动作以及表单相应

  • 权限控制

  • 菜单

  • 帮助函数

  • 开发工具

  • 自定义登陆

  • 自定义头部导航

  • 更新日志

目录

数据导出

# 数据导出

系统默认使用Easy Excel作为导出工具,支持导出 csv、 xlsx 和 ods 等格式文件。

使用前必须先安装Easy Excel:

composer require dcat/easy-excel

提示

默认不开启导出功能。

# 启用导出功能

启用或禁用导出功能

$grid->export();

禁用 导出所有 选项

$grid->export()->disableExportAll();

禁用 导出选中行 选项

$grid->export()->disableExportSelectedRow();

禁用 导出当前页 选项

$grid->export()->disableExportCurrentPage();

# 导出文件类型

提示

默认导出 xlsx 格式文件。

// csv
$grid->export()->csv();

// xlsx
$grid->export()->xlsx();

// ods
$grid->export()->ods();

# 设置列标题

提示

如果设置了标题,那么导出的文件的列数与标题的列数相同,且列的排序也相同。

// 只导出 id, name和email 三列数据
$titles = ['id' => 'ID', 'name' => '名称', 'email' => '邮箱'];

$grid->export($titles);

// 也可以这么使用
$grid->export()->titles($titles);

# 处理导出数据

$grid->export()->rows(function (array $rows) {
    foreach ($rows as $index => &$row) {
        $row['name'] = $row['first_name'].' '.$row['last_name'];
    }
    
    return $rows;
});

# 设置导出文件名

$grid->export()->filename('管理员数据');

# 扩展导出功能

如果系统内置的导出功能不了自己的需求,可以按照下面的步骤来自定义导出功能

本示例用Laravel-Excel (opens new window)作为excel操作库,当然也可以使用任何其他excel库

首先安装好它:

composer require maatwebsite/excel:~2.1.0

php artisan vendor:publish --provider="Maatwebsite\Excel\ExcelServiceProvider"

然后新建自定义导出类,比如app/Admin/Extensions/ExcelExpoter.php:

<?php

namespace App\Admin\Extensions;

use Dcat\Admin\Grid\Exporters\AbstractExporter;
use Maatwebsite\Excel\Facades\Excel;

class ExcelExpoter extends AbstractExporter
{
    public function export()
    {
        Excel::create('Filename', function($excel) {

            $excel->sheet('Sheetname', function($sheet) {
                
                 // 最多导出10W条数据
                 // 必须设置maxSize,当否则选择导出所有选项时只能导出默认的20条数据。
                $maxSize = 10000;

                // 这段逻辑是从表格数据中取出需要导出的字段
                $rows = collect($this->buildData(1, $maxSize))->map(function ($item) {
                    return array_only($item, ['id', 'title', 'content', 'rate', 'keywords']);
                });

                $sheet->rows($rows);

            });

        })->export('xls');
    }
}

然后在model-grid中使用这个导出类:


use App\Admin\Extensions\ExcelExpoter;

$grid->export(new ExcelExpoter());

有关更多Laravel-Excel的使用方法,参考laravel-excel/docs (opens new window)

表格规格筛选器
快捷创建

← 表格规格筛选器 快捷创建→

Theme by Vdoing | Copyright © 2020-2022 wyz.xyz 宁ICP备15001739号-5
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×