将HTML 前端生成的 table 作为数据源下载
思路
1 将 html 脚本 通过form post到后端
导出为EXCEL文档 | ||||
标题1 | 标题2 | 标题3 | 标题4 | 标题5 |
data | data | data | data | data |
html代码 编码后放到一个 form隐藏域
var source=escape("
导出为EXCEL文档 | ||||
标题1 | 标题2 | 标题3 | 标题4 | 标题5 |
data | data | data | data | data |
页面做点击下载事件 将form提交
2 php接住 作为数据源输出 附件
// 将 前段 抛过来的 html代码 解码 function phpUnescape($escstr) { preg_match_all("/%u[0-9A-Za-z]{4}|%.{2}|[0-9a-zA-Z.+-_]+/", $escstr, $matches); $ar = &$matches[0]; $c = ""; foreach($ar as $val) { if (substr($val, 0, 1) != "%") { $c .= $val; } elseif (substr($val, 1, 1) != "u") { $x = hexdec(substr($val, 1, 2)); $c .= chr($x); } else { $val = intval(substr($val, 2), 16); if ($val < 0x7F) // 0000-007F { $c .= chr($val); } elseif ($val < 0x800) // 0080-0800 { $c .= chr(0xC0 | ($val / 64)); $c .= chr(0x80 | ($val % 64)); } else // 0800-FFFF { $c .= chr(0xE0 | (($val / 64) / 64)); $c .= chr(0x80 | (($val / 64) % 64)); $c .= chr(0x80 | ($val % 64)); } } } return $c; } $file="test.xls";if(isset($_POST)&&$_POST["datasource"]){ //将 html写入 excel文件 $test=$_POST["datasource"]; header("Content-type: application/vnd.ms-excel"); header("Content-Disposition: attachment; filename=$file"); echo phpUnescape($_POST["downloaddata"]);}
这样一来 excel.php文件就可以接受任何抛过来的 html 代码(样式可能丢失)