Подтвердить что ты не робот

Плагин Table2excel не работает

Я работаю над приложением панели инструментов, и я хотел бы реализовать функцию "загрузить таблицу как .xls".

По этой ссылке вы можете увидеть, как выглядит таблица панель мониторинга

Я нашел библиотеку которая также включает в себя руководство, объясняющее настройку. Как вы можете видеть в приведенном ниже кодексе, я сделал более или менее все, что было объяснено. Однако это не работает, и по какой-то причине таблица не будет экспортироваться.

Как вы можете видеть, я включил 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="#" onclick="location.href='http://code.jquery.com/ui/1.9.2/themes/base/jquery-ui.css'; return false;" />

    <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 отлично работает.

Если вы видите, что может вызвать эту проблему, пожалуйста, помогите мне исправить это. Если у вас есть идея, как экспортировать таблицу в качестве файла excel, пожалуйста, предложите.

спасибо заранее.

Изменить 1:

Я изменил функцию, и это похоже на код, который я опубликовал ниже. Если я выполнил console.log("exporting..."); до или после $(".table2excel").table2excel({ ... }); "exp......", будет распечатан на консоли. Очевидно, что исключает jQuery как потенциальную причину проблемы.

<script>
        $(function () {
            $('#btnExport').click(function () {
                console.log("exporting...");
                $(".table2excel").table2excel({
                    exclude: ".noExl",
                    name: "Excel Document Name",
                    filename: "myFileName"
                });    
            });
        });
    </script>

Изменить 2:

Поскольку я не смог это исправить, я попытался попробовать что-то новое. Я нашел этот решения, и он работает, но все же не так, как мне бы хотелось, поэтому я надеюсь, что вы можете помочь мне улучшить его.

Моя таблица выглядит так: Table in html

и это то, что я получаю в результате Table in excel

Прежде всего, это выглядит странно без excel grid, у вас есть идея, почему файл экспортируется без него и как я могу добавить его?

Вторым я хотел бы удалить столбец после 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));
}

спасибо!

4b9b3361

Ответ 1

добавить это перед возвратом

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

вы можете играть вокруг строки в замене (перед запятой) на этом сайте: regexr.com

больше информации о многострочном совпадении здесь

Ответ 2

Убедитесь, что ссылка script для вашего плагина находится после jQuery, а также проверьте, что оба они включены до вашего js-кода.

Ответ 3

<!DOCTYPE html>
<html lang="zh-cn">
    <head>
        <meta charset="UTF-8">
        <title>人数统计</title>

        <style type="text/css">
            td,
            th {
                vertical-align: middle !important;
                text-align: center;
            }

            .bg_yellow{
                background-color: #fff45c;
            }

            .bg_green {
                background-color: #80c269;
            }
        </style>
    </head>

    <body>
<button>导出按钮</button>
    <table class="table table-bordered" style="width: 95%; margin: 20px auto;">
                            <thead>
                                <tr>
                                    <th scope="col" rowspan="2">a</th>
                                    <th scope="col" colspan="16">b</th>
                                    <th scope="col" colspan="16">c</th>
                                    <th scope="col" colspan="4">d</th>
                                    <th scope="col" rowspan="2">e</th>
                                </tr>
                                <tr>
                                    <th scope="col">f</th>
                                    <th scope="col">g</th>
                                    <th scope="col">h</th>
                                    <th scope="col" class="bg_green">i</th>
                                    <th scope="col">j</th>
                                    <th scope="col">k</th>
                                    <th scope="col">l</th>
                                    <th scope="col">m</th>
                                    <th scope="col">n</th>
                                    <th scope="col">o</th>
                                    <th scope="col" class="bg_green">p</th>
                                    <th scope="col">q</th>
                                    <th scope="col">l</th>
                                    <th scope="col">r</th>
                                    <th scope="col" class="bg_green">s</th>
                                    <th scope="col" class="bg_yellow">t</th>
                                    <th scope="col">u</th>
                                    <th scope="col">v</th>
                                    <th scope="col">w</th>
                                    <th scope="col" class="bg_green">x</th>
                                    <th scope="col">1</th>
                                    <th scope="col">2</th>
                                    <th scope="col">3</th>
                                    <th scope="col">4</th>
                                    <th scope="col">5</th>
                                    <th scope="col">6</th>
                                    <th scope="col" class="bg_green">z</th>
                                    <th scope="col">7</th>
                                    <th scope="col">8</th>
                                    <th scope="col">9</th>
                                    <th scope="col" class="bg_green">y</th>
                                    <th scope="col" class="bg_yellow">z</th>
                                     <th scope="col">7</th>
                                    <th scope="col">8</th>
                                    <th scope="col">9</th>
                                    <th scope="col" class="bg_yellow">z</th>
                                </tr>
                            </thead>

                            <tbody>
                                <tr>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow03">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow03">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_yellow03">0</td>
                                    <td>0</td>
                                </tr>

                                <tr>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow03">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow03">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_yellow03">0</td>
                                    <td>0</td>
                                </tr>

                                <tr>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_yellow">0</td>
                                    <td>0</td>
                                </tr>

                                <tr>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_yellow">0</td>
                                    <td>0</td>
                                </tr>

                                <tr>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_green">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td></td>
                                    <td></td>
                                    <td></td>
                                    <td class="bg_yellow">0</td>
                                    <td>0</td>
                                </tr>

                                <tr>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow"></td>
                                    <td class="bg_yellow">0</td>
                                    <td class="bg_yellow">0</td>
                                </tr>
                            </tbody>
                        </table>

    <script src="../dist/jquery.js"></script>
    <script src="../dist/jquery.table2excel.min.js"></script>
<script>
    $(function(){
        $("body").on("click","button",function(){
            exportExcel();
        });
        function exportExcel(){
            $(".table").table2excel({
                exclude: ".noExl",//不导出的表格数据选择器,不导出的数据加class加上 noExl就可以了
                name: "Excel Document Name",
                filename: "myFileName",
                fileext: ".xls",
                exclude_img: true,
                exclude_links: true,
                exclude_inputs: true
            });
        }
    })
</script>
    </body>
</html>