jquery:根据另一列的属性在一个表列上更新css

时间:2017-12-17 10:49:16

标签: javascript jquery html css

这是我的HTML表格

<!DOCTYPE html>
<html>
<body>
<table>
<thead>
<th>Header1</th>
<th>Header2</th>
</thead>
<tbody>
<tr>
<td><input type="checkbox" id=0 /></td>
<td>TEXT1</td>
</tr>
<tr>
<td><input type="checkbox" id=1 checked/></td>
<td>TEXT2</td>
</tr>
</tbody>
</table>

</body>
</html>

please click here

我的目标是扫描表格中的所有行(在加载页面之后)并通过jquery更新第二列文本的css(显示在链接中)

例如,上面的表格应该如上所示(通过TEXT2元素通过)

我相信我们可以使用jquery的css方法设置元素的css,如下所示

.css("text-decoration", "line-through")

但我很遗憾如何构建一个jquery片段,可以扫描表中的所有行并执行css。

这在jquery中真的可行吗?

任何帮助表示赞赏!!!

2 个答案:

答案 0 :(得分:2)

<强> 1。初始化脚本

要在页面加载后运行脚本,请考虑将.on()方法与load事件一起使用。

参考:.on() | jQuery API Documentation

<强> 2。迭代指定的元素:

要遍历必需的元素,请考虑将.each()方法与指定的css选择器td > input一起使用,以直接定位input元素的嵌套td元素(从而绕过碰巧嵌套在任何特定input元素中的所有td元素的目标,并且无需链接另一个.find()方法来指定所需的嵌套元素。

参考:.each() | jQuery API Documentation

3.检查所需条件:

要验证相关元素是否具有属性checked,请考虑使用条件语句(如if())来检查条件是否计算为true }。
如果 ,则使用条件语句块中的.css()方法添加所需的内联样式

参考:.css() | jQuery API Documentation

代码段示范:

&#13;
&#13;
$(window).on('load', function(){
  
  $('td > input').each(function(){
    if($(this).attr('checked')) {
      $(this).parent().next().css('text-decoration', 'line-through');
    }
  });
  
});
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table>
  <thead>
    <th>Header1</th>
    <th>Header2</th>
  </thead>
  <tbody>
    <tr>
      <td><input type="checkbox" id="text0" /></td>
      <td>TEXT1</td>
    </tr>
    <tr>
      <td><input type="checkbox" id="text1" checked/></td>
      <td>TEXT2</td>
    </tr>
  </tbody>
</table>
&#13;
&#13;
&#13;

注意:

    如果值以整数开头,则
  1. id选择器无效 (数字/单位值),例如:id="0",值必须以a开头 字符串,例如:id="text0"
  2. 用撇号包裹属性值,例如:id="text0"

答案 1 :(得分:0)

我在Jquery做过这个:

在选中复选框的第二列上删除文字。

但还包括用于删除第二列上的文本是用户用户点击复选框

ConverterParameter=
$(document).ready(function(){
 $('input:checkbox').on('change', function () {
        var inpt = $(this).parent().next('td');
        if (this.checked) {
           
            $(inpt).css('textDecoration', 'line-through');
        } else {
            $(inpt).css('textDecoration', 'none');
        }
    });
  var i=   $('input[type=checkbox]:checked').parent().next('td');
  if ($('input[type=checkbox]:checked')) {
           
            $(i).css('textDecoration', 'line-through');
            }
    });