Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/70.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 使用jquery导出html,包括分页_Php_Jquery_Html_Mysql - Fatal编程技术网

Php 使用jquery导出html,包括分页

Php 使用jquery导出html,包括分页,php,jquery,html,mysql,Php,Jquery,Html,Mysql,我面临的问题是,使用从互联网上某个地方获得的代码片段,我可以完美地创建xls。我的html表中的文件(使用mysql/php创建),但它不会显示所有结果。它只抓取它在前端看到的行。但是我使用分页,在后台还有其他结果。如何调整代码,使其也能从其他页面获取信息 var tableToExcel = (function () { var uri = 'data:application/vnd.ms-excel;base64,', template = '<

我面临的问题是,使用从互联网上某个地方获得的代码片段,我可以完美地创建xls。我的html表中的文件(使用mysql/php创建),但它不会显示所有结果。它只抓取它在前端看到的行。但是我使用分页,在后台还有其他结果。如何调整代码,使其也能从其他页面获取信息

var tableToExcel = (function () {
    var uri =
        'data:application/vnd.ms-excel;base64,',
        template = '<html xmlns:o="urn:schemas-microsoft-com:office:office"
     xmlns:x="urn:schemas-microsoft-com:office:excel"
     xmlns="http://www.w3.org/TR/REC-html40"><head><!--[if gte mso
     9]><xml><x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet><x:Name>{worksheet}</x:Name><x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions></x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook></xml><![endif]--></head><body><table>{table}</table></body></html>',
        base64 = function (s) {
            return window.btoa(unescape(encodeURIComponent(s)))
        }, format = function (s, c) {
            return s.replace(/{(\w+)}/g, function (m, p) {
                return c[p];
            })
        }
    return function (table, name) {
        if (!table.nodeType) table = document.getElementById(table)
        var ctx = {
            worksheet: name || 'Worksheet',
            table: table.innerHTML
        }
        window.location.href = uri + base64(format(template, ctx))
    }
})()
var tableToExcel=(函数(){
var-uri=
'数据:application/vnd.ms excel;base64',
模板=“{table}”,
base64=函数{
返回窗口.btoa(unescape(一个或多个组件)))
},格式=函数(s,c){
返回s.replace(/{(\w+)}/g,函数(m,p){
返回c[p];
})
}
返回函数(表、名称){
如果(!table.nodeType)table=document.getElementById(table)
变量ctx={
工作表:名称| |‘工作表’,
表:table.innerHTML
}
window.location.href=uri+base64(格式(模板,ctx))
}
})()
查看插件或jQuery。它处理分页、导出到excel,以及可以对数据表执行的大量其他很酷的操作


它将为您节省一个复杂的JS函数,就像您在上面发布的那样。

是的,谢谢。我已经做过了。但当我插入函数时,总是会收到一条错误消息:DataTables警告(table id='a1'):无法重新初始化DataTable。若要检索此表的DataTables对象,请不要传递任何参数或查看Bretrive和bDestroI的文档,我将对此提出一个新问题,而不是尝试在此处修复它。确保包含您的表HTML和正在运行的javascript以及错误。我认为让DataTables为您工作,而不是试图让脚本在整个web上工作,这将是一个真正的好处。不过,谷歌似乎说,这一错误可能是因为您在表加载到页面之前运行javascript。试着将脚本放在表格下面,看看这是否有区别:-)@ChrisMcKinnel它需要在用户机器上安装flash。有没有不使用swf文件的解决方案?