本文实例讲述了jquery+php实现导出datatables插件数据到excel的方法。分享给大家供大家参考。具体如下:

DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点:

1. 自动分页处理

2. 即时表格数据过滤

3. 数据排序以及数据类型自动检测

4. 自动处理列宽度

5. 可通过CSS定制样式

6. 支持隐藏列

7. 易用

8. 可扩展性和灵活性

9. 国际化

10.动态创建表格

11.免费

插件地址http://www.datatables.net/

不过可惜的是官方网站表格数据导出方法使用的是tabletools插件,利用flash导出数据,而且不支持中文数据,通过查找官方的API和资料,找到使用jquery和php导出数据方法。

导出数据的javascript函数

function table2csv(oTable, exportmode, tableElm) {

var csv = '';

var headers = [];

var rows = [];

// Get header names

$(tableElm+' thead').find('th').each(function() {

var $th = $(this);

var text = $th.text();

var header = '"' + text + '"';

// headers.push(header); // original code

if(text != "") headers.push(header); // actually datatables seems to copy my original headers so there ist an amount of TH cells which are empty

});

csv += headers.join(',') + "\n";

// get table data

if (exportmode == "full") { // total data

var total = oTable.fnSettings().fnRecordsTotal()

for(i = 0; i < total; i++) {

var row = oTable.fnGetData(i);

row = strip_tags(row);

rows.push(row);

}

} else { // visible rows only

$(tableElm+' tbody tr:visible').each(function(index) {

var row = oTable.fnGetData(this);

row = strip_tags(row);

rows.push(row);

})

}

csv += rows.join("\n");

// if a csv div is already open, delete it

if($('.csv-data').length) $('.csv-data').remove();

// open a div with a download link

$('body').append('

'+csv+'');

}

function strip_tags(html) {

var tmp = document.createElement("div");

tmp.innerHTML = html;

return tmp.textContent||tmp.innerText;

}

函数支持导出所有数据和当前页数据

// export only what is visible right now (filters & paginationapplied)

$('#export_visible').click(function(event) {

var oTable;

oTable= $('#spdata').dataTable();

event.preventDefault();

table2csv(oTable, 'visible', '#spdata'); })

// export all table data

$('#export_all').click(function(event) {

var oTable;

oTable= $('#spdata').dataTable();

event.preventDefault();

table2csv(oTable, 'full', '#spdata'); })

其中#spdata是table的id

后台php导出excel代码

header("Content-Type: application/vnd.ms-execl");

header("Content-Disposition: attachment; filename=myExcel.csv");

header("Pragma: no-cache");

header("Expires: 0");

$buffer = $_POST['csv'];

$buffer=str_replace(",",",\t",$buffer);

$buffer=mb_convert_encoding($buffer,"GB2312","UTF-8");

echo $buffer;

希望本文所述对大家的php程序设计有所帮助。

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

php 导出tables,jquery+php实现导出datatables插件数据到excel的方法_php技巧相关推荐

  1. php导出excel数据代码,phpspreadsheet导出数据到Excel的方法介绍(代码示例)

    本篇文章给大家带来的内容是关于phpspreadsheet导出数据到Excel的方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 之前我们使用PHP导出Excel数 ...

  2. python mysql导出到excel_python:mysql导出数据到excel工具方法

    近期肺炎严重,春节期间都在家闭关,闲暇时间捡起了之前学习的python,刚好最近在项目上处理大批量数据,从数据库导出数据效率比较低,就想通过python实现导出,结果效率果然很高,基本5-10秒内就导 ...

  3. php输出json到表格,Vue如何导出json数据到Excel电子表格方法

    本文主要介绍了Vue导出json数据到Excel电子表格的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望能帮助到大家. 一.安装依赖(前面基本一样) npm install file- ...

  4. QT导出数据到Excel的方法

    一.系统库中自带的写入方法写入Excel 使用QAxObject,系统自带的参数. 使用方法参考:https://blog.csdn.net/cannon_qi/article/details/799 ...

  5. php 导出大数据量excel 解决方法 秒出 并不会出现PHPExcel内存溢出问题

    最近公司需要每天生成亚马逊广告调价报告报表 并且文件格式必须为excel 数据量超过10w+ 使用PHPExcel组件 加上生成器yield 并且设置单元格对象缓存 还是会导致内存爆掉 最后使用了PH ...

  6. C#读取Excel表格数据到DataGridView中和导出DataGridView中的数据到Excel

    其实想在datagridview中显示excel表格中的数据跟读取数据库中的数据没什么差别,只不过是创建数据库连接的时候连接字段稍有差别. private void btnShow_Click(obj ...

  7. JavaScript导出图片和数据到Excel

    JavaScript导出图片和数据到Excel 以下方法可以利用json数据将图片地址生成图片导出到Excel,同样也可以将数据导出到Excel.解决网上许多方法关于导出图片到Excel却无法让图片在 ...

  8. Qt导出数据到excel

    Qt导出数据到excel Qt导出数据到excel,方法有很多,Qt里也有自带的axcontainer模块中的#include<QAxObject>类可以导出数据到excel,但是这种方法 ...

  9. Javascript实现导出word - jquery jquery.wordexport.js 实现导出word

    Javascript实现导出word - jquery.wordexport.js 实现导出word 由于工作需要,将一个页面导出word文档,主要是简历!经过百度搜索之后,没找到结果,无奈之下只能求 ...

最新文章

  1. USB获取图像实时处理
  2. 在 Virt-manager 图形界面中使用桥接网络
  3. Input.GetTouch 获取触摸
  4. PHP生成条形码 之二 开源之道
  5. Python3爬虫-01-简单网页爬取
  6. php入门02-数组
  7. CDN视频流中的3个问题以及解决方法
  8. JUnit 4和JUnit 5区别
  9. 基于界面自动化测试框架的发展
  10. SpringMVC jsp界面值渲染不出来
  11. 38..Node.js工具模块---底层的网络通信--Net模块
  12. iOS 开发常用链接总结
  13. python黑网站_python
  14. ubuntu docker-compose: command not found
  15. python爬虫跳过付费数据_Python爬虫教程:包图网免费付费素材爬取!
  16. 《跨界杂谈》华为印象(二):MTS
  17. 用turtle绘图做一个钟表时钟
  18. VR全景制作方法教程完整版
  19. python剪辑视频 裁剪_用python进行视频剪辑
  20. android拓展内存卡,都取消存储卡拓展,而它却解决了安卓手机的大问题

热门文章

  1. 大数据分析平台建模及建议
  2. 商业数据分析的层次与步骤有哪些
  3. 阿里天池用Pandas揭秘美国选民的总统喜好附加题
  4. c语言求一个数因数个数,【代码】求一个数的因数和、求优化、顺便也供新人参考算法...
  5. emmap erlang_erLang学些笔记2—基本类型
  6. Linux中yum不能用的原因
  7. 微信jssdk配置的问题,使用MVC制作的demo
  8. 谈谈MySQL InnoDB存储引擎事务的ACID特性
  9. Python 爬虫 (三) - Socket 网络编程
  10. celery 、rabbitmq的exchange三种方式的实现