jquery+php实现导出datatables插件数据到excel的方法
发布:smiling 来源: PHP粉丝网 添加日期:2021-06-08 17:22:56 浏览: 评论:0
这篇文章主要介绍了jquery+php实现导出datatables插件数据到excel的方法,实例分析了jquery插件datatables的使用方法与php导出datatables数据到Excel的技巧,需要的朋友可以参考下
本文实例讲述了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('<div class="csv-data"><form enctype="multipart/form-data" method="post" action="/csv.php"><textarea class="form" name="csv">'+csv+'</textarea><input type="submit" class="submit" value="Download as file" /></form></div>');
- }
- 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;
Tags: jquery+php datatables
相关文章
- ·分享jQuery+PHP实现的掷色子抽奖实例(2015-04-04)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)