javascript - jQuery:选择 `<td>` 中除特定 `<tr>` 之外的所有 `<td>`

标签 javascript jquery html jquery-selectors

我想选择所单击的 tr 中除具有输入复选框的 td 之外的所有 td。以下代码允许我不选择具有输入字段的 td:

$(".table-row td:not(:has(input))").click(function(){...}

但我无法访问另一个 td 的值。

是什么原因导致这个问题?如何选择除特定 td 之外的所有 td

.html

<tr data-id="{{ test.id }}" class="table-row">
 <td class="form-check">
  <div class="form-check">
   <label class="form-check-label">
    <input class="form-check-input check-ele check-prevent" type="checkbox" value="">
    <span class="form-check-sign">
     <span class="check"></span>
    </span>
   </label>
  </div>
 </td>
 <td>{{ forloop.counter }}</td>
 <td name="test_name">{{ test.test_name}}</td>
 <td name="test_type">{{ test.test_type}}</td>
 <td name="test_date">{{ test.test_date|date:"m/d/Y" }}</td>  
</tr>  

jQuery

$(".table-row td:not(:has(input))").click(function(){
  $('#editModal').modal('show');
  let row = $(this).closest('tr').attr('data-id');
  var test_name = $(this).find('td[ name="test_name" ]').text();
  console.log(typeof(test_name));
  // return empty test_name. The row I click on has test_name with value `Entrance Exam`
  var test_type = $(this).find('td[ name="test_type" ]').text();
  var test_date = $(this).find('td[ name="test_date" ]').text();
  var date = new Date(test_date);
  var day = ("0" + date.getDate()).slice(-2);
  var month = ("0" + (date.getMonth() + 1)).slice(-2);
  var test_date = date.getFullYear()+"-"+(month)+"-"+(day) ;
  $('#edit_test_date').val(test_date);
  $("#edit_test_name").val(test_name);
  $("#edit_test_type").val(test_type);

最佳答案

您的选择器工作正常,如以下示例所示,但您正在访问其他 <td>是错误的。这是另一种方法:

const cells = $(".table-row td:not(:has(input))");

cells.click((e) => {
  const row = e.target.parentElement;
  const [ name, type, date ] = Array.from(row.children).slice(2).map(cell => cell.getAttribute('name'));
  
  console.log(`NAME = ${ name }, TYPE = ${ type }, DATE = ${ date }`)
});
table {
  border-collapse: collapse;
  border: 3px solid black;
  width: 100%;
  text-align: center;
  font-family: monospace;
}

td {
  padding: 10px 20px;
}

td:not(:first-child) {
  cursor: pointer;
  border-left: 3px solid black;
}

td:not(:first-child):hover {
  background: yellow;
}

.as-console-wrapper {
  max-height: 44px !important;
}
<table>
  <tr class="table-row">
    <td>
      <div>
        <label>
          <input type="checkbox" value="">
        </label>
      </div>
    </td>
    <td name="counter1">Counter 1</td>
    <td name="name1">Name 1</td>
    <td name="type1">Type 1</td>
    <td name="date1">Date 1</td>  
  </tr>
  
  <tr class="table-row">
    <td>
      <div>
        <label>
          <input type="checkbox" value="">
        </label>
      </div>
    </td>
    <td name="counter2">Counter 2</td>
    <td name="name2">Name 2</td>
    <td name="type2">Type 2</td>
    <td name="date2">Date 2</td>  
  </tr>
  
  <tr class="table-row">
    <td>
      <div>
        <label>
          <input type="checkbox" value="">
        </label>
      </div>
    </td>
    <td name="counter3">Counter 3</td>
    <td name="name3">Name 3</td>
    <td name="type3">Type 3</td>
    <td name="date3">Date 3</td>  
  </tr>
</table>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

您的代码中的问题在这里:

let row = $(this).closest('tr').attr('data-id');
var test_name = $(this).find('td[ name="test_name" ]').text();

您应该选择实际行 ( <tr> ) 而不是其 data-id属性,然后使用 row查找不同的单元格及其 name 的值属性:

const row = $(this).closest('tr');
const test_name = row.find('td[name="name1"]').text();

关于javascript - jQuery:选择 `<td>` 中除特定 `<tr>` 之外的所有 `<td>`,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51114670/

相关文章:

javascript - 解析xml文档

javascript - 函数未被调用

html - 对齐元素在同一行

javascript链接按钮以改变颜色

html - 我如何为移动设备设置最小宽度并且不更改 Bootstrap 3 中的视口(viewport)?

javascript - 如果 javascript 在第三方网站上,如何从 javascript 对 REST API 进行身份验证?

javascript - 一个非常简单的 JSON 调用在控制台中产生 JS 错误 : "Unexpected token u"

javascript - 如何使用 iframe 取消文件上传

jQuery比较并找出2个json数组之间的差异

javascript - 介绍 : when using intro background images appear above popup