如何检查数据表中是否存在某个值?

3

有没有一种方法可以在现有的datatable中查找特定的值? 找到它后,我想将行信息放入单个变量中,例如像选定的那样获取数据

$('#datatable').DataTable().rows({selected:true}).data();

现在我希望它能像搜索一样工作,如果我输入two并且datatable在特定列上具有该值,它将在if else中给我true,然后我希望将该值存储在javascript变量中。

我也知道如何获取datatable中的所有数据。 我只是不知道如何使用if else获取单行数据。 感谢您的帮助!

编辑:

这是我想发生的事情

用户将输入数据 > 系统将检查该数据是否存在于datatable中 > 如果不存在,则会出现错误 > 如果存在,则将整个行存储在变量中,例如:var data = //整个行数据


如果你有一个count()函数,你可以使用它来测试值是否为0(不存在)或大于0(存在)。 - Yaelet
在datatable上计数?如果是所有数据,我知道计数的工作原理。但我不知道如何为单个数据进行过滤。 - Jovs
$('#datatable').DataTable().rows({selected:true}).data(); 这会返回一个数组,对吧?你能遍历这个数组并检查其中是否存在该值吗? - VTodorov
我知道它是如何工作的。数据不是由用户选择的,用户只会输入数据,我希望系统检查输入的数据是否存在于数据表中。 - Jovs
然后在您的数据单元格上添加一个 onChange 事件监听器。并在那里检查该值。 - VTodorov
显示剩余3条评论
1个回答

2

尝试使用{search: 'applied'}选择器修饰符

最初的回答

var table = $('#example').DataTable()

console.log(table.search('Tokyo').row({search: 'applied'}).data())
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.datatables.net/1.10.19/js/jquery.dataTables.min.js"></script>
<link href="https://cdn.datatables.net/1.10.19/css/jquery.dataTables.min.css" rel="stylesheet" />


<table id="example" class="display" style="width:100%">
  <thead>
    <tr>
      <th>Name</th>
      <th>Position</th>
      <th>Office</th>
      <th>Numero</th>
      <th>Start date</th>
      <th>Salary</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>Tiger Nixon</td>
      <td>System Architect</td>
      <td>Edinburgh</td>
      <td>155555</td>
      <td>2011/04/25</td>
      <td>$320,800</td>
    </tr>
    <tr>
      <td>Garrett Winters</td>
      <td>Accountant</td>
      <td>Tokyo</td>
      <td>63</td>
      <td>2011/07/25</td>
      <td>$170,750</td>
    </tr>
    <tr>
      <td>Ashton Cox</td>
      <td>Junior Technical Author</td>
      <td>San Francisco</td>
      <td>1</td>
      <td>2009/01/12</td>
      <td>$86,000</td>
    </tr>
  </tbody>
</table>


它是否具有仅搜索特定列的功能? - Jovs
$(...).search is not a function got this error. I tried this one alert($('#asset-table').search('Stocked').row({search: 'applied'}).data()); - Jovs
解决了!非常感谢! - Jovs

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接