jquery-datatables 销毁重新渲染

为什么要销毁重新渲染?

  1. 解决表格数据更换后数据不更新问题
  2. 解决列名更换后tbody中列的错位问题

渲染表格对象

<body>
    <div id="tableBox">
        <table class="dataTable table table-bordered " cellspacing="0" cellpadding="0"></table>
    </div>
</body>

<script>
    var Table = null;
    var option={
        data:data,
        columns:columns,
        ...
    }
    Table = $("#tableBox table").DataTable(option)
</script>

怎么样销毁表格对象?

这里存在一个误区:认为生成的只有一个存在变量中表格对象,将其销毁后就可以了。其实datatable生成的表格对象是有两部分构成:一为数据对象; 二为Dom对象

<script>

    //删除表格对象
    if(Table){
        Table.destroy();
        Table.clear();
        Table=null; 
        //删除dom中的标签片段
        $("#table").html("") 
        //重新加入table标签
        $("#table").append("<table class="dataTable table table-bordered " cellspacing="0" cellpadding="0"></table>"); 
    
    }

</script>

    原文作者:阿莎
    原文地址: https://segmentfault.com/a/1190000017775697
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞