删除多个类以“重置”Div

时间:2013-02-28 19:50:50

标签: jquery css

以下解决我自己的答案:

  

解释 .removeClass()不接受逗号列出多个类。


我正在构建一个充满细胞的智能数据网格,这些细胞将识别(模糊)它们是否被更改,以及值是否上升或下降。

这就是它的样子。当用户悬停已更改的框时,会显示灰色工具提示,并告诉他们首次加载页面时的值。


enter image description here


问题:当我降低单元格中的值时,模糊,然后将其更改回原来的状态,单元格会正确删除所有已更改的指示(没有红色/绿色边框,没有箭头,没有工具提示)。

然而,当我提升单元格中的值时,模糊,然后将其更改回原来的状态,它没有摆脱绿色边框。我检查了我的代码,我不明白为什么它没有删除“up”类。

  

示例:将左上角的单元格从12,000更改为11,000。单击单元格。注意红色边框。现在将它改回12,000。它   现在应该重置为灰色。

     

现在将值更改为13,000。单击单元格。注意绿色   边界。现在将它改回12,000。它应该是绿色的   已重置为灰色。

你们能给我一些第二眼看出我的问题所在吗?也许建议一种方法来浓缩我的“细胞重置”?

相关HTML(full code available HERE):

<tr>
    <td><input type="text" value="12000" /></td>
    <td><input type="text" value="1000" /></td>
    <td><input type="text" value="100000" /></td>
</tr>

相关CSS(full code available HERE):

.up { border:1px solid #0F0 !important; }
.down { border:1px solid #F00 !important; }

.down-indicator {
    // some styles to create a downward triangle
}

.up-indicator {
    // some styles to create an upward triangle
}

相关jQuery(full code available HERE):

$(function() {
    var initialValues = [];

    $('input').each(function(index) {
        initialValues[index] = $(this).val();
        $(this).data('id', index);
    });


    $("input").blur(function() {
        var $t = parseInt($(this).val(), 10);
        var $s = parseInt(initialValues[$(this).data('id')], 10);

        // value has changed
        if($t != $s) {
            $(this).parent().append("<div class='tooltip'>" + $s + "</div>");
        }

        // value is the same as initial value
        if($t == $s) {
            $(this).removeClass("up, down");
            $(this).parent().children(".tooltip").remove();
            $(this).parent().children(".up-indicator, .down-indicator").remove();
        }

        // value went up
        else if($t > $s) {
            $(this).removeClass("up, down");
            $(this).parent().children(".up-indicator, .down-indicator").remove();
            $(this).addClass("up");
            $(this).parent().append("<div class='up-indicator'></div>");
        }

        // value went down
        else if($t < $s) {
            $(this).removeClass("up, down");
            $(this).parent().children(".up-indicator, .down-indicator").remove();
            $(this).addClass("down");
            $(this).parent().append("<div class='down-indicator'></div>");
        }
    });

1 个答案:

答案 0 :(得分:0)

我发现了我的问题。似乎.removeClass()不使用逗号分隔多个类。

旧代码:

$(this).removeClass("up, down");

固定代码:

$(this).removeClass("up down");

WORKING FIDDLE