jQuery, если у DIV нет класса "x" - PullRequest
       12

jQuery, если у DIV нет класса "x"

205 голосов
/ 06 февраля 2009

В jQuery мне нужно сделать оператор if, чтобы проверить, содержит ли $ this класс '.selected'.

$(".thumbs").hover(function(){

$(this).stop().fadeTo("normal", 1.0);
},function(){
$(this).stop().fadeTo("slow", 0.3);

});

В основном, когда эта функция запускается (при наведении), я не хочу выполнять замирания, если класс «.selected» был добавлен к div, это будет означать, что изображение будет в полной непрозрачности, чтобы показать это выбрано. Поиск в Google не принес удачи, хотя это простой вопрос о том, как использовать оператор IF ...

Ответы [ 7 ]

347 голосов
/ 06 февраля 2009

Используйте селектор "not ".

Например, вместо:

$(".thumbs").hover()

попробовать:

$(".thumbs:not(.selected)").hover()

175 голосов
/ 06 февраля 2009

jQuery имеет функцию hasClass (), которая возвращает true, если какой-либо элемент в упакованном наборе содержит указанный класс

if (!$(this).hasClass("selected")) {
    //do stuff
}

Взгляните на мой пример использования

  • Если вы наводите курсор на элемент div, он исчезает как нормальная скорость до 100% непрозрачности, если div не содержит «selected» класс
  • Если вы парите из div, он исчезает на медленной скорости до 30% непрозрачности, если div не содержит «selected» класс
  • Нажатие на кнопку добавляет «выбранные» класс для красного div. Угасание эффекты больше не работают на красном div

Вот код для этого

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.1/jquery.min.js"></script>
<title>Sandbox</title>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<style type="text/css" media="screen">
body { background-color: #FFF; font: 16px Helvetica, Arial; color: #000; }
</style>


<!-- jQuery code here -->
<script type="text/javascript">
$(function() {

$('#myButton').click(function(e) {
$('#div2').addClass('selected');
});

$('.thumbs').bind('click',function(e) { alert('You clicked ' + e.target.id ); } );

$('.thumbs').hover(fadeItIn, fadeItOut);


});

function fadeItIn(e) {
if (!$(e.target).hasClass('selected')) 
 { 
    $(e.target).fadeTo('normal', 1.0); 
  } 
}

function fadeItOut(e) { 
  if (!$(e.target).hasClass('selected'))
  { 
    $(e.target).fadeTo('slow', 0.3); 
 } 
}
</script>


</head>
<body>
<div id="div1" class="thumbs" style=" background-color: #0f0; margin: 10px; padding: 10px; width: 100px; height: 50px; clear: both;"> 
One div with a thumbs class
</div>
<div id="div2" class="thumbs" style=" background-color: #f00; margin: 10px; padding: 10px; width: 100px; height: 50px; clear: both;">
Another one with a thumbs class
</div>
<input type="button" id="myButton" value="add 'selected' class to red div" />
</body>
</html>

EDIT:

это всего лишь предположение, но вы пытаетесь достичь чего-то подобного ?

  • Оба div начинаются с непрозрачности 30%
  • При наведении курсора на делитель исчезает до 100% непрозрачности, при наведении вниз до 30% непрозрачности. Эффекты затухания работают только с элементами, которые не имеют выделенного класса
  • Нажатие на div добавляет / удаляет выбранный класс

jQuery код здесь-

$(function() {

$('.thumbs').bind('click',function(e) { $(e.target).toggleClass('selected'); } );
$('.thumbs').hover(fadeItIn, fadeItOut);
$('.thumbs').css('opacity', 0.3);

});

function fadeItIn(e) {
if (!$(e.target).hasClass('selected')) 
 { 
    $(e.target).fadeTo('normal', 1.0); 
  } 
}

function fadeItOut(e) { 
  if (!$(e.target).hasClass('selected'))
  { 
    $(e.target).fadeTo('slow', 0.3); 
 } 
}

<div id="div1" class="thumbs" style=" background-color: #0f0; margin: 10px; padding: 10px; width: 100px; height: 50px; clear: both; cursor:pointer;"> 
One div with a thumbs class
</div>
<div id="div2" class="thumbs" style=" background-color: #f00; margin: 10px; padding: 10px; width: 100px; height: 50px; clear: both; cursor:pointer;">
Another one with a thumbs class
</div>
26 голосов
/ 16 ноября 2011

Я думаю, что автор искал:

$(this).not('.selected')
4 голосов
/ 12 августа 2011

Когда вы проверяете, есть ли у элемента класс или нет, убедитесь, что вы случайно не поставили точку в имени класса:

<div class="className"></div>

$('div').hasClass('className');
$('div').hasClass('.className'); #will not work!!!!

После долгого взгляда на мой код я понял, что сделал это. Такая опечатка заняла у меня час, чтобы понять, что я сделала неправильно. Проверьте свой код!

1 голос
/ 27 июля 2009
$(".thumbs").hover(
    function(){
        if (!$(this).hasClass("selected")) {
            $(this).stop().fadeTo("normal", 1.0);
        }
    },
    function(){
        if (!$(this).hasClass("selected")) {
            $(this).stop().fadeTo("slow", 0.3); 
        }           
    }
);

Помещение if внутри каждой части наведения позволяет динамически изменять класс выбора, и наведение все равно будет работать.

$(".thumbs").click(function() {
    $(".thumbs").each(function () {
        if ($(this).hasClass("selected")) {
            $(this).removeClass("selected");
            $(this).hover();
        }
    });                 
    $(this).addClass("selected");                   
});

В качестве примера я также добавил обработчик кликов, чтобы переключить выбранный класс на выбранный элемент. Затем я запускаю событие наведения на предыдущий элемент, чтобы он исчез.

0 голосов
/ 06 февраля 2009

Как насчет того, чтобы вместо использования if внутри события вы открепляли событие, когда применяется класс select? Я предполагаю, что вы добавляете класс в ваш код где-то, поэтому отмена привязки события будет выглядеть так:

$(element).addClass( 'selected' ).unbind( 'hover' );

Единственным недостатком является то, что если вы когда-либо удаляете выбранный класс из элемента, вы должны снова подписать его на событие hover.

0 голосов
/ 06 февраля 2009

Вы также можете использовать методы addClass и removeClass для переключения между такими элементами, как вкладки.

, например

if($(element).hasClass("selected"))
   $(element).removeClass("selected");
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...