利用form.submit提交表单导出文件到客户端浏览器, 提示下载!
本来是想利用ajax提交json数据到服务端, 让服务端生成一个excel文件并提示客户端浏览器下载的. 但是搞了很久发现ajax方式是无法触发浏览器弹出文件下载的.
网上很多的方案都是说利用form提交, 还有就是纯客户端js去生成excel文件. 这两种方案都是可行的, 今天只演示第一种.
浏览器上展示了一堆数据, 有个按钮是导出按钮,点击后触发一个事件, 提交数据到服务端, 由服务端来生成excel文件流并提示浏览器下载!

按钮的点击:
onExportExcel = () => {
....... 这里准备好需要提交到服务端的数据
const inputs = {
data,
header,
columnWidth,
filename,
};
this.exportExcel('/xx1/xx2/exportExcel', inputs);
}
exportExcel(url, data) // 导出数据到excel文件
{
const form = document.createElement('form');
form.style = "display:none;";
form.method = "post";
form.action = url;
const input = document.createElement('input');
input.type = 'hidden';
input.name = 'values';
input.value = Base64.encode(JSON.stringify(data));
form.appendChild(input);
$('body').append(form);
form.submit();
form.remove();
}
这里用了一个Base64.encode()接口(下载), 这里是关键, 因为普通的input表单一般是用于传递字符串的, 但是因为我这里要传递的是一个object对象(也可认为是json数据), 所以我就想到了将json序列化后并base64编码下(不编码的话, 服务端接收到的值有可能json_decode会失败). ==> 所以服务端在接收时要采取相反的方向先base64_decode, 再调用json_decode才能得到原始的json数据!
服务端代码(php, thinkcmf5.0):
public function exportExcel()
{
$values = request()->post('values');
$values = base64_decode($values); $list = json_decode($values, true);
if(!$list)
{
_return(1, '没有数据, 无法导出到文件');
} log_message($list); $data = $list['data'];
$header = $list['header'];
$columnWidth = $list['columnWidth'];
$filename = $list['filename']; if (empty($data) || empty($header) || empty($filename)) {
$this->success('success');
return;
} ExcelModule::exportFile($data, $header, $columnWidth, $filename);
}
ExcelModule::exportFile是我自已写的一个类, 封装的一个静态接口函数
class ExcelModule
{
/**
* 导出数据到excel文件并提供下载
* @param array $data
* @param array $fileheader
* @param array $columnWidth
* @param $savefile
* @param string $sheetname
* @throws \PHPExcel_Exception
* @throws \PHPExcel_Reader_Exception
* @throws \PHPExcel_Writer_Exception
*/
public static function exportFile(array $data, array $fileheader, array $columnWidth, $savefile, $sheetname = 'MySheet')
{
Vendor('PHPExcel.PHPExcel.IOFactory');
$excel = new \PHPExcel();
//防止中文命名,下载时ie9及其他情况下的文件名称乱码
// iconv('UTF-8', 'GB2312', $savefile);
$objActSheet = $excel->getActiveSheet();
//根据有生成的excel多少列,$letter长度要大于等于这个值
$letter = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V');
//设置当前的sheet
$excel->setActiveSheetIndex(0);
//设置sheet的name
$objActSheet->setTitle($sheetname);
//设置表头
for ($i = 0; $i < count($fileheader); $i++) {
// 单元宽度自适应,1.8.1版本phpexcel中文支持勉强可以,自适应后单独设置宽度无效
// $objActSheet->getColumnDimension("$letter[$i]")->setAutoSize(true);
$objActSheet->getColumnDimension("$letter[$i]")->setWidth($columnWidth[$i]);
// 设置表头值,这里的setCellValue第二个参数不能使用iconv,否则excel中显示false
$objActSheet->setCellValue("{$letter[$i]}1", $fileheader[$i]);
// 设置表头字体样式
$objActSheet->getStyle("{$letter[$i]}1")->getFont()->setName('微软雅黑');
//设置表头字体大小
$objActSheet->getStyle("{$letter[$i]}1")->getFont()->setSize(12);
//设置表头字体是否加粗
// $objActSheet->getStyle("{$letter[$i]}1")->getFont()->setBold(true);
//设置表头文字垂直居中
$objActSheet->getStyle("{$letter[$i]}1")->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
//设置文字上下居中
$objActSheet->getStyle("$letter[$i]")->getAlignment()->setVertical(\PHPExcel_Style_Alignment::VERTICAL_CENTER);
//设置表头外的文字垂直居中
$excel->setActiveSheetIndex(0)->getStyle("$letter[$i]")->getAlignment()->setHorizontal(\PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
} $j = 2;
foreach ($data as $k => $v) {
$i = 0;
foreach ($v as $key => $value) {
$objActSheet->setCellValue($letter[$i] . $j, $value);
// $objActSheet->getColumnDimension("$letter[$i]")->setAutoSize(true);
$objActSheet->getColumnDimension("$letter[$i]")->setWidth($columnWidth[$i]);
$i++;
}
$j++;
}
header('Content-Type: application/vnd.ms-excel');
//下载的excel文件名称,为Excel5,后缀为xls,不过影响似乎不大
header('Content-Disposition: attachment;filename="' . $savefile . '.xls"');
header('Cache-Control: max-age=0');
// 用户下载excel
$objWriter = \PHPExcel_IOFactory::createWriter($excel, 'Excel2007');
$objWriter->save('php://output');
exit;
}
}
我这个php服务端是thinkcmf5.0框架下的, 包含了很多现成的库!
最终效果:

利用form.submit提交表单导出文件到客户端浏览器, 提示下载!的更多相关文章
- submit()提交表单时,显示警示框
我同事在实现submit()提交表单时,想要页面弹出警示框. 但是折腾了几小时后发现,submit()始终不执行. 她的代码如下: $(document).ready(function(){ $(&q ...
- 用js怎么控制submit提交表单
需求: 1. 要在点击submit按钮的时候,弹出一个询问框,"你确定要修改?".如果按了"确定"那么就提交表单,否则就保留在原页面,既不提交不跳转. 2. 要 ...
- php使用jquery Form ajax 提交表单,并上传文件
在html5中我们通过FormData就可以ajax上传文件数据,不过因为兼容问题.我们选用jquery.form.min.js来进行ajax的表单提交. 一.jquery.form.js下载地址 ...
- submit提交表单后,不刷新当前页面
<form method="get" target="test" action="a.html"> <input type ...
- 使用jquery.form.js提交表单上传文件
方法: 1.formSerilize() 用于序列化表单中的数据,并将其自动整理成适合AJAX异步请求的URL地址格式. 2.clearForm() 清除表单中所有输入值的内容. 3.restF ...
- JS 控制 form是否提交表单
问题背景:用php删除数据,希望在点击“删除”(button)的时候JS弹出confirm来确认是否删除. 此段代码为php中的form: <form action="?form=de ...
- 利用iframe实现提交表单是页面部分刷新
直接上代码: <%@ page language="java" import="java.util.*" pageEncoding="utf-8 ...
- submit提交表单
<!DOCTYPE html><html><head> <script src="jquery-1.3.2.min.js">< ...
- 用layui的 form.on提交表单如何禁止刷新页面
答:只需要在 form.on里面的底部添加return false;即可 例如: form.on('submit(component-form-demo1)', function(data){ var ...
随机推荐
- java报错:The reference to entity "characterEncoding" must end with the ';' delimiter.
java关于报错:The reference to entity "characterEncoding" must end with the ';' delimiter. Java ...
- SpringMVC 字节流实现播放多媒体
1.前言 在项目中,我们会遇到在线预览,播放MP3.图片.MP4等.用户上传文件后,将路径存储在数据库中,我们可动态读取数据库的数据,然后通过返回文件路径的字符串,在src中发送请求.当然这需要带参数 ...
- Beta/Gamma事后分析
目录 设想和目标 计划 资源 变更管理 设计/实现 测试/发布 团队的角色,管理,合作 总结 对照敏捷开发的原则, 你觉得你们小组做得最好的是哪几个原则? 请列出具体的事例. 照片 设想和目标 我们的 ...
- Linux搭建Nexus3.X构建maven私服
备注:linux版本: ubuntu 同时已经部署好JDK8环境 一.linux安装nexus 1.创建文件夹并进入该目录 cd /usr/local && mkdir nexus & ...
- Laravel jwt 多表验证隔离
为什么要做隔离 当同一个laravel项目有多端(移动端.管理端......)都需要使用jwt做用户验证时,如果用户表有多个(一般都会有),就需要做token隔离,不然会发生移动端的token也能请求 ...
- Vue父组件如何调用子组件(弹出框)中的方法的问题
如果子组件是一个弹出框,只有在触发某个点击事件时弹出框才能出现(也就是说在父组件中的子组件使用上用了v-if),那在父组件上如果不点击弹出框是不能获取到$ref的. 原因就是:引用指向的是子组件创建的 ...
- MIME类型对应表:
MIME类型对应表: 常用MIME类型: 扩展名 MIME类型 .iso ISO File .rar application/x-rar-compressed .zip application/zip ...
- MySQL面试题及答案整理,史上最全!
原文链接:https://juejin.im/post/5d351303f265da1bd30596f9 前言 本文主要受众为开发人员,所以不涉及到MySQL的服务部署等操作,且内容较多,大家准备好耐 ...
- texstudio基本设置
一开始默认为英文,在上面菜单栏,“option” 1.设置中文:options->general->language->zh-cn 2.编辑和查看按钮: 3.设置默认编译器:选项-& ...
- 【转】Apache的架构师们遵循的30条设计原则
本文作者叫Srinath,是一位科学家,软件架构师,也是一名在分布式系统上工作的程序员. 他是Apache Axis2项目的联合创始人,也是Apache Software基金会的成员. 他是WSO2流 ...