【问题标题】:How to make dataTable.js work in this example (dynamic jQuery Table)?如何使 dataTable.js 在这个例子中工作(动态 jQuery 表)?
【发布时间】:2016-12-27 23:46:30
【问题描述】:

我需要使用 datatable 向我在此示例中创建的表添加排序、分页和搜索。但是,我无法让它工作。我花了很多时间来缓解类型错误,但没有运气。每当我尝试添加数据表时,都会出现此错误:

“未捕获的类型错误:无法读取未定义的属性‘长度’”

请提出解决方案。我已经使用过 Bootstrap 表和 dynatable。我需要数据表来解决我的实时 dom 排序问题。

这是我的代码:

    <!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/1.10.13/css/jquery.dataTables.min.css">
<script type="text/javascript" charset="utf8" src="https://cdn.datatables.net/1.10.13/js/jquery.dataTables.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous">
</head>
<body>
<div class="container">
  <form >
  <div class="form-group"> <!-- Email field !-->
    <label for="name" class="control-label">Name</label>
    <input type="name" class="form-control" id="name" name="name" placeholder="John Doe">
  </div>
  <div class="form-group"> <!-- Email field !-->
    <label for="mail" class="control-label">Mail</label>
    <input type="mail" class="form-control" id="mail" name="mail" placeholder="name@domain.com">
  </div>
  <div class="form-group"> <!-- Email field !-->
    <label for="mobile" class="control-label">Mobile No.</label>
    <input type="mobile" class="form-control" id="mobile" name="mobile" placeholder="xxx-xxx-xxxx">
  </div>
  <div class="form-group"> <!-- Submit button !-->
  <a id="add_row" type="submit" class="btn btn-default pull-left">Add Row</a><a id='delete_row' class="pull-right btn btn-default">Delete</a>
  </div>  
</form>
    <div class="row clearfix">
    <div class="col-md-12 column">
      <table  class="table table-bordered table-hover" id="tab_logic" ">
        <thead>
          <tr >
            <th class="text-center">
              #
            </th>
            <th class="text-center">
              Name
            </th>
            <th class="text-center">
              Mail
            </th>
            <th class="text-center">
              Mobile
            </th>
          </tr>
        </thead>
        <tbody>
        <tr id='addr0'></tr>
        </tbody>
      </table>
    </div>
  </div>
</div>
<script type="text/javascript">
$(document).ready(function(){    
    var i=0;
    $("#add_row").on('click',function(){
        var name= $("#name").val();
        var mail =$("#mail").val();
        var mobile=$("#mobile").val();
        console.log("THE NAME IS "+ name);
       $('#addr'+i).html("<td>"+ (i+1) +"</td><td>" +name+ "</td><td>" +mail+"</td><td> "+mobile+"</td>");
       $('#tab_logic').append('<tr id="addr'+(i+1)+'"></tr>');
       i++; 

    });
     $("#delete_row").click(function(){
       if(i>0){
     $("#addr"+(i-1)).html('');
     i--;
     }
   });
       $("#tab_logic").dataTable();

});
</script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
</body>
</html>

我确保在从我的研究中导入 dataTables 之前只使用一次 jQuery。

【问题讨论】:

  • 您确定您提供的代码会出现错误吗?你能做一个 JSFiddle 吗?

标签: javascript jquery datatables


【解决方案1】:

您需要在第一行创建列或将其删除:

<table  class="table table-bordered table-hover" id="tab_logic" ">
        <thead>
          <tr >
            <th class="text-center">
              #
            </th>
            <th class="text-center">
              Name
            </th>
            <th class="text-center">
              Mail
            </th>
            <th class="text-center">
              Mobile
            </th>
          </tr>
        </thead>
        <tbody>
        <tr id='addr0'>
          <td></td>
          <td></td>
          <td></td>
          <td></td>
        </tr>
        </tbody>
      </table>

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-10-05
    • 2017-11-26
    • 2021-10-14
    • 2021-10-05
    • 1970-01-01
    • 2014-10-22
    • 2018-08-04
    • 1970-01-01
    相关资源
    最近更新 更多