jQuery - addClass или removeClass - есть класс дополнения? - PullRequest
3 голосов
/ 11 марта 2010

У меня css наведите курсор на изображения для моих вкладок, и я пытаюсь изменить класс с .how на .how_on при нажатии на изображение КАК.

Мои вкладки

КАК | ЧТО | КОГДА | ВОЗ | ПОЧЕМУ

У меня есть классы для каждого (.how, .how_on), (.what, .what_on) и т. Д. ...

Можно ли заставить jQuery добавить _on к исходному имени класса с помощью click (function () {});

HTML:

<div id="tab_container">
     <ul class="tabs">
        <li><a class="how_on" href="#how">How</a></li>
        <li><a class="why" href="#why">Why</a></li>
        <li><a class="what" href="#what">What</a></li>
        <li><a class="who" href="#who">Who</a></li>
        <li><a class="when" href="#when">When</a></li>
    </ul>
    <p><img src="images/tab_top.jpg" width="864px" height="6px" alt="" border="0" /></p>
</div>
<div class="tab_body">
    <!-- HOW -->
        <div id="how" class="tab">
            <strong>HOW IT WORKS:</strong>
        </div>

Jquery:

<script type="text/javascript">
jQuery(document).ready(function(){
 //if this is not the first tab, hide it
 jQuery(".tab:not(:first)").hide();
 //to fix u know who
 jQuery(".tab:first").show();
 //when we click one of the tabs
 jQuery(".tabs a").click(function(){
 //get the ID of the element we need to show
 stringref = jQuery(this).attr("href").split('#')[1];




 // adjust css on tabs to show active tab





 //hide the tabs that doesn't match the ID
 jQuery('.tab:not(#'+stringref+')').hide();
 //fix
 if (jQuery.browser.msie && jQuery.browser.version.substr(0,3) == "6.0") {
 jQuery('.tab#' + stringref).show();
 }
 else
 //display our tab fading it in
 jQuery('.tab#' + stringref).fadeIn();
 //stay with me
 return false;
 });

});
</script>

CSS:

.tabs
{
    width: 683px;
    height: 29px;
    padding: 0;
    margin: 0;
    display: inline;
    float: left;
    overflow: hidden;
    list-style-type: none;
}

.tabs li
{
    margin: 0;
    padding: 0;
    display: inline;
    float: left;
}

.tabs  a {  background-position: 0 -58px;}
.tabs .on a {   background-position: 0 -29px;}

.how,
a.how:link,
a.how:visited
{
  float: left;
  display: inline;
  width: 135px;
  height: 29px;
  margin: 0;
  text-decoration: none;
  text-indent: -99999px;
  overflow: hidden;  
  background-image: url("../images/how_tab.jpg");
}

Ответы [ 8 ]

3 голосов
/ 11 марта 2010

Когда вы используете addClass, он добавляет / добавляет класс, если вы сначала не удалите некоторые из них, используя removeClass, поэтому вам нужно сделать следующее:

$('.how_on').mouseover(function(){
    $(this).removeClass('class_name').addClass('class_name');
});

$('.why').mouseover(function(){
    $(this).removeClass('class_name').addClass('class_name');
});

// and so on.........
3 голосов
/ 11 марта 2010

Я бы хотел, чтобы у jQuery это было, но, насколько я могу судить, его нет. Вы всегда можете использовать removeClass, чтобы избавиться от одной версии, и addClass, чтобы добавить другую. Кроме того, вы можете приготовить свой собственный маленький плагин. Похоже, полезная вещь, чтобы сделать; даже jQuery UI имеет дело с манипулированием всеми его классами ("ui-state-default", "ui-state-hover" и т. д.), и было бы проще, если бы он мог просто вызвать API для обновления ствола класса "ui -state- "с выбранным суффиксом.

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

// to go from "foo" to "foo_on":
function turnOn(which) {
  $('.tabs').find('a.' + which)
    .removeClass(which)
    .addClass(which + '_on');
};

// to go from "foo_on" to "foo"
function turnOff(which) {
  $('.tabs').find('a.' + which + '_on')
    .removeClass(which + '_on')
    .addClass(which);
}

Затем вы вызываете turnOn("how"), когда хотите, чтобы вкладка «как» переключалась на класс «how_on», и turnOff("how"), чтобы перевести ее с «how_on» на «как».

2 голосов
/ 11 марта 2010

ОБНОВЛЕНИЕ:

Попробуйте это:

$('.tabs a').click(function() {
    $('.tabs a').removeAttr('id'); // remove all ids
    $(this).attr('id', this.className + "_on") // create how_on as this id.
});

Вы используете имя класса для создания уникального идентификатора. Это сделает то же самое, что вы пытаетесь сделать. Вот пример с выбранным «почему».

 <ul class="tabs">
    <li><a class="how" href="#how">How</a></li>
    <li><a id='why_on' class="why" href="#why">Why</a></li>
    <li><a class="what" href="#what">What</a></li>
    <li><a class="who" href="#who">Who</a></li>
    <li><a class="when" href="#when">When</a></li>
 </ul>

Конечно, Самый простой способ состоит в том, чтобы добавить класс .how_on и иметь оба класса.

<div class='how how_on'>some stuff</div>

В этом нет ничего плохого, и вы можете легко переопределить стили или выбрать элемент.

.how { color: #000; }
div.how_on { color: #F00; } /* increased specificity */

Если вы хотите убедиться, что он переопределяет его, увеличьте специфичность.

1 голос
/ 11 марта 2010

Вы можете полностью заменить jQuery Part на эту;

Это должно работать как положено!

JAVASCRIPT PART

$(function() {

    var tabs = $('div.tab_body > div.tab');
    tabs.hide().filter(':first').show();

    $('div#tab_container ul.tabs a').click(function() {
        tabs.hide();
        var myhash = this.hash.split('#')[1];

        tabs.filter(this.hash).show();

        $('a:not(.' + myhash + '_on)').each(function() {
            var h = this.hash.split('#')[1];
            $(this).removeClass(h + '_on').addClass(h);
        });
        $(this).removeClass(myhash).addClass(myhash + '_on');

        return false;
    }).filter(':first').click();
});

HTML PART

<div id="tab_container">
 <ul class="tabs">
    <li><a class="how" href="#how">How</a></li>
    <li><a class="why" href="#why">Why</a></li>
    <li><a class="what" href="#what">What</a></li>
    <li><a class="who" href="#who">Who</a></li>
    <li><a class="when" href="#when">When</a></li>
</ul>            
</div>

<div class="tab_body">
    <div id="how" class="tab">
        <strong>how</strong>
    </div>
    <div id="why" class="tab">
        <strong>why:</strong>
    </div>
    <div id="what" class="tab">
        <strong>what</strong>
    </div>
    <div id="who" class="tab">
        <strong>who</strong>
    </div>
    <div id="when" class="tab">
     <strong>when</strong>
    </div>
  </div>

Надеюсь, это поможет!

Привет

1 голос
/ 11 марта 2010

всегда можно сделать:

jQuery(".tabs a").click(function(){
    this.className += '_on';
}

, который добавит нужный суффикс.

еще лучше будет добавить класс «активации» к содержащему «li».

jQuery(".tabs a").click(function(){
    $(this).parent().toggleClass('on');
}

и ваш css должен выглядеть так:

/* here i removed the 'a.how_on' entry */
.how,
a.how:link,
a.how:visited
{
  float: left;
  display: inline;
  width: 135px;
  height: 29px;
  margin: 0;
  text-decoration: none;
  text-indent: -99999px;
  overflow: hidden;  
}

a.how:visited, a.how:link, a.how:hover
{
    background-image: url("../images/how_tab.jpg");
    background-position: 0 -58px;
}

/* this will cause the link to behave different when its parent is of class on */
.on a.how
{
    background-image: url("../images/how_tab.jpg");
    background-position: 0 -29px;
}

и вы можете определить общее поведение для своих вкладок, связав это

.tabs a { /* style */ }
.tabs a:link { /* link style */ }
.tabs a:hover { /* hover style */ }

.tabs .on a { /* activated style */ }
.tabs .on a:link { /* activated link style */ }
.tabs .on a:hover { /* activated hover style */ }
1 голос
/ 11 марта 2010
.addClass( function(index, class) )

addClass принимает анонимную функцию, и вы можете добавить логику для добавления класса здесь

как

$('ELEMENT SELECTION').addClass(function() {
  return $(this).attr("class") + 'CLASS TO BE ADDED';
});
0 голосов
/ 11 марта 2010

Почему бы вам просто не добавить класс on к рассматриваемым элементам и изменить свои правила CSS с .how and .how_on на .how and .how.on?

Затем в вашем .how.on вы можете просто переопределить все, что установлено в .how, которое вы хотите изменить.

Я не думаю, что вам нужно сгибать JavaScript / jQuery по своему усмотрению, скорее используйте специфичность CSS для того, для чего он предназначен.

0 голосов
/ 11 марта 2010

Есть несколько подходов.

  1. Удалите класс, добавьте _on к строке и добавьте новый класс.
  2. Просто создайте свои *_on классы для изменения оригинальных стилей классов. Тогда все, что вам нужно сделать, это удалить класс *_on, чтобы вернуться к старому стилю.
...