DataTables没有检测到thead?

时间:2016-01-15 08:23:16

标签: javascript jquery css datatables

我正在寻找一种显示一个非常大的表的方法,该表既有固定的标题也有列,所以我认为fixedColumns功能可以正常工作。事实证明,该插件甚至无法正确分割我的表。我正在将我的表的结果与dataTables scrollXY演示进行比较。

如果相关,网站基于Django,所以我使用内置过滤器来生成thead。在初始AJAX调用之后,结果也会在每行附加到tbody之前通过过滤器。由于'aoColumns [srCol]未定义'错误导致表无法加载,因此我在违规列上将bSortable切换为false。通过scrollX和scrollY激活,我得到this

我检查了HTML并且dataTables无法将thead从tbody中分离出来(两者都在scrollBody中),只有排序箭头保留在scrollHead中。我从ScrollXY演示中包含了几乎所有的CSS和JS(并删除了我的所有内容),所以我不确定我错过了什么。我尝试了jQuery 1.11.3和2.1.4,结果是一样的。

如果我能够找到如何使用Django之外的数据库值生成演示页面,我将使用代码更新帖子。这是我的表使用CSS,td链接和没有dataTables的样子。 The inspector shows that the table markup is correct.

现在我可以从页面发布相关代码,但是错误是将ID和链接添加到td元素中的结果吗?

<link rel="stylesheet" type="text/css" href="{% static "css/gridism.css" %}">
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.10/css/jquery.dataTables.min.css">
<style type="text/css">
    div.dataTables_wrapper {
        width: 800px;
        margin: 0 auto;
    }
</style>
<script type="text/javascript" language="javascript" src="https://cdn.datatables.net/1.10.10/js/jquery.dataTables.min.js"></script>
<script type="text/javascript" charset="utf-8">
    $(document).ready(function() {
        $.ajax({
            url: 'modlist/1/',
            success: function(data){
                $("#t_master").empty();
                $("#t_master").html("<thead><tr><th>Name</th><th>Institution</th><th>Designation</th><th>Expected date of graduation</th>{% for m in modules %}<th class='module'><a href='module/{{ m.ID }}'>{{ m.topic }}</a></th>{% endfor %}<th>Email</th><th>Contact number</th></tr></thead><tbody></tbody>");
                var table = document.getElementById("t_master").getElementsByTagName("tbody")[0];
                var index = 0;
                var prevname;
                data.forEach(function(obj) {
                    var date = 0;
                    var name = obj.sname + ', ' + obj.fname;
                    if (obj.graddate) date = obj.graddate.toString();
                    var row = document.createElement('tr');
                    if (index%2) row.className = 'alt';
                    if (obj.graddate) {
                        row.innerHTML = '<td><a href="participant/'+ obj.ppant_id +'">' + name + '</a></td><td><a href="institution/' + obj.instn_id + '">' + obj.abbrev + '</a></td><td>' + obj.designation + '</td><td>' + date.substring(0,4) + ' ' + date.substring(4,5) + 'H</td>' + {% for m in modules %} '<td id="td_master_{{ m.ID }}_' + String(index) + '"></td>' + {% endfor %} '<td>' + obj.email + '</td><td>' + obj.contactn + '</td>';
                    }
                    else {
                        row.innerHTML = '<td><a href="participant/'+ obj.ppant_id +'">' + name + '</a></td><td><a href="institution/' + obj.instn_id + '">' + obj.abbrev + '</a></td><td>' + obj.designation + '</td><td>N/A</td>' + {% for m in modules %} '<td id="td_master_{{ m.ID }}_' + String(index) + '"></td>' + {% endfor %} '<td>' + obj.email + '</td><td>' + obj.contactn + '</td>';
                    }
                    if (prevname != name){
                        table.appendChild(row);
                        modcell = document.getElementById('td_master_'+obj.mod_id+'_'+String(index));
                        modcell.innerHTML = '<center><a href="training/' + obj.training_id + '">★</a></center>';
                        index++;
                    }
                    else {
                        modcell = document.getElementById('td_master_'+obj.mod_id+'_'+String(index-1));
                        modcell.innerHTML = '<center><a href="training/' + obj.training_id + '">★</a></center>';
                    }
                    prevname = name;
                });
            }
        });
    });
    $(document).ready(function() {
        $("#t_master").dataTable({
            scrollY: 500,
            scrollX: true,
            aoColumns: [
                null,
                null,
                null,
                null,
                {% for m in modules %}{bSortable:false},{% endfor %}
                {bSortable:false},
                {bSortable:false}
            ]
        });
    });
</script>

<div id="g_master"><table id="t_master" class="display table hover stripe" cellspacing="0" width="100%"></table></div>

1 个答案:

答案 0 :(得分:0)

没关系,我的小提琴上班了。 dataTable()函数调用是一个粗心的错误,应该在$(document).ajaxSuccess()而不是$(document).ready()上完成。