Jquery 表排序器n[0]未定义
我与表排序器有问题。错误是: n[0]未定义Jquery 表排序器n[0]未定义,jquery,asp.net,html-table,tablesorter,Jquery,Asp.net,Html Table,Tablesorter,我与表排序器有问题。错误是: n[0]未定义 function appendToTable(table,cache) { if(table.config.debug) {var appendTime = new Date()} var c = cache, r = c.row, n= c.normalized, totalRows = n.le
function appendToTable(table,cache) {
if(table.config.debug) {var appendTime = new Date()}
var c = cache,
r = c.row,
n= c.normalized,
totalRows = n.length,
checkCell = (n[0].length-1),
tableBody = $(table.tBodies[0]),
rows = [];
for (var i=0;i < totalRows; i++) {
rows.push(r[n[i][checkCell]]);
if(!table.config.appender) {
var o = r[n[i][checkCell]];
var l = o.length;
for(var j=0; j < l; j++) {
tableBody[0].appendChild(o[j]);
}
//tableBody.append(r[n[i][checkCell]]);
}
}
下面是客户端
<asp:Repeater ID="reviewRepeater" runat="server">
<HeaderTemplate>
<table cellpadding="0" cellspacing="0" class="MarkAsReceived" id="reviewTable">
<thead>
<tr class="even">
<th align="left">Review ID</th>
<th align="left">Date Submitted</th>
<th align="left">Rating</th>
<th align="left">Image</th>
<th align="left">ProductId</th>
<th align="left">Status</th>
<th align="left">Name</th>
</tr>
</thead>
<tbody>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "ReviewId")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "SubmissionDate")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "Rating")%></td>
<td align="left"><%#hasImage(DataBinder.Eval(Container.DataItem, "ReviewerImages"))%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "ProductId")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "Status")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "Nickname")%></td>
</tr>
</ItemTemplate>
<AlternatingItemTemplate>
<tr>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "ReviewId")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "SubmissionDate")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "Rating")%></td>
<td align="left"><%#hasImage(DataBinder.Eval(Container.DataItem, "ReviewerImages"))%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "ProductId")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "Status")%></td>
<td align="left"><%#DataBinder.Eval(Container.DataItem, "Nickname")%></td>
</tr>
</AlternatingItemTemplate>
<FooterTemplate>
</tbody>
</table>
<asp:Label ID="lblEmpty" Text="No Items." runat="server" Visible='<%# reviewRepeater.Items.Count == 0 %>'></asp:Label>
</FooterTemplate>
</asp:Repeater>
审查ID
提交日期
评级
形象
产品ID
地位
名称
如果我记得的话,您会得到这个错误,因为表最初是空的(tbody)。因此,从以下内容修改该行代码:
checkCell = (n[0].length-1),
为此:
checkCell = totalRows ? (n[0].length - 1) : 0,
如果您感兴趣,我已经为github上最初的tablesorter插件添加了许多增强功能(包括上面的更改)
checkCell = totalRows ? (n[0].length - 1) : 0,