我正在使用仪表板应用程序,并且想实现“将表下载为.xls”功能。

在此链接上,您可以看到表格的外观
dashboard

我找到了library,其中还包括说明设置的教程。正如您在下面的代码中看到的那样,我已经或多或少地完成了与所解释的一样的所有工作。但是,它不起作用,由于某种原因,该表将不会导出。

如您所见,我已经在资源中包括jquery.table2excel.js以及此页面使用的所有其他资源。我还检查了页面加载后.js文件是否可用,并且看起来也不错。

我也尝试过

    $(function () {
            document.getElementById('btnExport').addEventListener("click", function () {
                document.getElementById('myTable').table2excel({
                    exclude: ".noExl",
                    name: "Excel Document Name",
                    filename: "myFileName"
                });
            });
        });

但是它看起来也不好,当我执行功能时,我在调试控制台中收到了此消息
TypeError: document.getElementById(...).table2excel is not a function
这是我现在的index.jsp的样子
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">

<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>KPI Admin</title>

    <link href="<c:url value="/resources/css/bootstrap.min.css" />" rel="stylesheet">
    <link href="<c:url value="/resources/css/addition.css" />" rel="stylesheet">
    <link rel="stylesheet" href="http://code.jquery.com/ui/1.9.2/themes/base/jquery-ui.css" />

    <script src="<c:url value="http://ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js" />"></script>
    <script src="<c:url value="http://code.jquery.com/ui/1.9.2/jquery-ui.js" />"></script>
    <script src="<c:url value="/resources/js/bootstrap.js" />"></script>
    <script src="<c:url value="/resources/js/addition.js" />"></script>
    <script src="<c:url value="/resources/js/jquery.table2excel.js" />"></script>
    <script>
        $(function () {
            document.getElementById('btnExport').addEventListener("click", function () {
                $(".table2excel").table2excel({
                    exclude: ".noExl",
                    name: "Excel Document Name",
                    filename: "myFileName"
                });
            });
        });
    </script>
</head>
<body>

<nav class="navbar navbar-inverse navbar-fixed-top">
    <!-- /.nav -->
</nav>

<div class="container">
    <div class="starter-template">

        <ul class="nav nav-tabs">
            <!-- /.tabs -->
        </ul>

        <!-- Tab panes -->
        <div class="tab-content">
            <div class="tab-pane fade in active" id="A">
                <form:form action="/KPIAdmin/kpis" method="get">


                    <div class="row form-inline">
                        <div class="form-group">
                            <label for="date">Date</label>
                            <input id="startDatePicker" type="text" class="form-control" name="date" value="${date}" >
                        </div>
                        <button type="submit" class="btn btn-default">Submit</button>
                    </div>
                    <br>

                    <div class="table-responsive">
                        <table id="myTable" class="table table-bordered table2excel">
                            <thead>
                                <tr>
                                    <td>Name</td>
                                    <td>Last import</td>
                                    <td>Last value</td>
                                    <td colspan="4">Values</td>
                                    <td colspan="3">Targets</td>
                                    <td colspan="3">Score</td>
                                    <td>Action</td>
                                </tr>
                            </thead>
                            <tr>
                                <td></td>
                                <td></td>
                                <td></td>
                                <td class="text-center" style="font-weight: 700;">DTD</td>
                                <td class="text-center" style="font-weight: 700;">WTD</td>
                                <td class="text-center" style="font-weight: 700;">MTD</td>
                                <td class="text-center" style="font-weight: 700;">YTD</td>
                                <td class="text-center" style="font-weight: 700;">0</td>
                                <td class="text-center" style="font-weight: 700;">100</td>
                                <td class="text-center" style="font-weight: 700;">150</td>
                                <td class="text-center" style="font-weight: 700;">WTD</td>
                                <td class="text-center" style="font-weight: 700;">MTD</td>
                                <td class="text-center" style="font-weight: 700;">YTD</td>
                                <td></td>
                            </tr>
                            <c:forEach var="row" items="${rows}" varStatus="loop">
                                <!-- /.loop that creates the table -->
                            </c:forEach>
                            <tr>
                                <!-- /. last row mean -->
                            </tr>
                        </table>
                    </div>

                </form:form>
                <button id="btnExport" class="btn btn-default">Export as .xls</button>
            </div>
            <div class="tab-pane fade" id="B"> <!-- Content inside tab B --> </div>
            <div class="tab-pane fade" id="C"> <!-- Content inside tab C --> </div>
        </div>

    </div>
</div><!-- /.container -->


我真的不确定是什么引起了这个问题,或者我在jQuery语法中有错误。也可能是lib在.jsp页面中没有正确输入,但这是过去为我工作的方式。我猜我正在使用正确的jQuery版本,因为jQuery datePicker可以正常工作。

如果您能看到可能导致此问题的原因,请帮助我修复它。如果您有更好的主意如何将表格导出为ex​​cel文件,请提出建议。

提前谢谢。

编辑1:

我更改了功能,它看起来像我在下面发布的代码。如果在console.log("exporting...");之前或之后执行$(".table2excel").table2excel({ ... });,“exporing ...”将在控制台中打印出来。显然,这不将jQuery视为问题的潜在原因。
<script>
        $(function () {
            $('#btnExport').click(function () {
                console.log("exporting...");
                $(".table2excel").table2excel({
                    exclude: ".noExl",
                    name: "Excel Document Name",
                    filename: "myFileName"
                });
            });
        });
    </script>

编辑2:

由于我无法解决此问题,因此我尝试尝试一些新的方法。我找到了this解决方案,它可以正常工作,但仍然无法实现,所以希望您能帮助我进行改进。

我的桌子看起来像这样

这就是我得到的结果

首先,如果没有excel网格,它看起来真的很奇怪,您是否有一个想法,为什么没有该文件就可以导出文件,又该如何添加呢?

其次,我想在YTD之后删除显示其他信息的列。是否可以通过某种方式调整下面的tab_text.replace(...)以实现此目的

在HTML中看起来像这样
</td><td width='20px'>
    <a class='infobox' href=''>
        <img src='img/info.jpg' alt='info' width='18' height='18'>
        <span> Service Engineer: ... <br>
               Datasource: ...
        </span>
    </a>
</tr>

JavaScript函数如下所示
function exportExcelReport(tblId) {
    var tab_text = "<table border='2px'><tr>";
    var table = document.getElementById(tblId);

    var style;
    for (var j = 0; j < table.rows.length; j++) {
        style = table.rows[j].className.split(" ");
        if (style.length < 2)
        tab_text = tab_text + table.rows[j].innerHTML + "</tr>";
    }

    tab_text = tab_text + "</table>";
    tab_text = tab_text.replace(/<a[^>]*>|<\/a>/g, "");
    tab_text = tab_text.replace(/<img[^>]*>/gi, "");
    tab_text = tab_text.replace(/<input[^>]*>|<\/input>/gi, "");

    return window.open('data:application/vnd.ms-excel,' + encodeURIComponent(tab_text));
}

谢谢!

最佳答案

返回之前添加此

tab_text = tab_text.replace(/<a class='infobox'[\s\S]*?<\/a>/gi, "");

您可以在此站点上的替换字符串中(在逗号之前)播放字符串:regexr.com

有关多行匹配here的更多信息

07-25 20:44