Я работаю над приложением панели инструментов, и я хотел бы реализовать функцию "загрузить таблицу как .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:
Поскольку я не смог это исправить, я попытался попробовать что-то новое. Я нашел этот решения, и он работает, но все же не так, как мне бы хотелось, поэтому я надеюсь, что вы можете помочь мне улучшить его.
Моя таблица выглядит так:
и это то, что я получаю в результате
Прежде всего, это выглядит странно без 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));
}
спасибо!