javascript - onChange 复选框高亮行

标签 javascript jquery html checkbox

我正在尝试使用一个我认为非常有用的脚本,但我一定没有得到它。这只是一个简单的复选框,突出显示行类型的脚本,但我被困在某个地方。

$(document).ready(function() {
  $("input[type='checkbox']").on('change', function() {
    if ($(this).is(":checked")) {
      $(this).closest('tr').addClass("highlight");

    } else {
      $(this).closest('tr').removeClass("highlight");
    }
  });
});
.highlight {
  background-color: red
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>


<table>
  <tr>
    <td><input id="checkboxSelect" type="checkbox"></td>
    <td>231540</td>
    <td>2018-02-25 00:00:00</td>
    <td>93.50</td>
  </tr>
  <table>

因此,当选中该特定行的复选框时,我希望能够将类“突出显示”添加到该复选框的表格行。

已更新//

我还使用以下脚本尝试了建议的答案之一:

$("#checkboxSelect").click(function(){
if ($(this).is(":checked")){
 $(this).parent().parent().removeClass("highlight");
 alert('hello');}
else{
$(this).parent().parent().addClass("highlight");
alert('goodbye');}
    });

它仍然不会触发,我已经在 jsFiddle 上对其进行了测试并且它确实可以在那里工作,但在我的环境中它就是不会触发。

如果这意味着什么,这在技术上是如何生成这些行的:

$.ajax({
            type:'GET',
            url: '/customers/details/openInvoices',
            dataType:'json',
            data: {
                'customerID': $('select[name=payer_id]').val(),
               '_token': $('input[name=_token]').val(),
            },
                success: function(data) {
                    $('.errorTitle').addClass('hidden');
                    $('.errorContent').addClass('hidden');

                    if ((data.errors)) {
                        setTimeout(function () {
                            $('#createOrigin').modal('show');
                            toastr.error('Check your inputs!', 'Error Alert', {timeOut: 5000});
                        }, 500);

                        if (data.errors.title) {
                            $('.errorTitle').removeClass('hidden');
                            $('.errorTitle').text(data.errors.title);
                        }
                        if (data.errors.content) {
                            $('.errorContent').removeClass('hidden');
                            $('.errorContent').text(data.errors.content);
                        }
                    } else {
                         $.each(data, function(i,val) {
                                    $('<tr>').append(
                                    $('<td>').html('<input type="checkbox" class="checkboxSelect">'),
                                    $('<td>').text(val.pro_number),
                                    $('<td>').text(val.due_date),
                                    $('<td>').text(val.balance)).appendTo('#customerOpenInvoicesTable');
                            $('#openInvoicesOverlay').html('');
                             $('#openInvoicesOverlay').removeClass('overlay');

               });
              }
             }
            });

最佳答案

使用 jquery..

并且不要忘记添加jquery cdn......

$("#checkboxSelect").click(function(){
if ($(this).is(":checked")){
 $(this).parent().parent().removeClass("highlight")}
else{
$(this).parent().parent().addClass("highlight")}
    });

这样就可以了...

关于javascript - onChange 复选框高亮行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48534779/

相关文章:

javascript - Cesiumjs:如何从 GeoJsonDataSource 迭代数据

javascript - Onclick 属性不适用于链接 (a href)

JQuery AJAX 如何获取和解析 JSONP 而不是 JSON?

html - 如何在 div 上固定和居中图像

html - Angular2 将数据传递给模态

javascript - 如何正确关闭 node-express 服务器?

javascript - 如何在使用 d3.js 滚动时将 x 轴保持在固定位置?

javascript - ng-repeat 中的 Angular 多复选框数组

jquery - 如何使用CSS3、HTML5、SVG、Jquery制作不规则曲线?

javascript - IE11 上的 fireEvent 方法问题