Теги, колеблющиеся как Переполнение стека с помощью [закрытого] jQuery

10
задан animuson 8 March 2015 в 20:52
поделиться

3 ответа

Это должно работать.

http://jsfiddle.net/5GD6r/4/

Я закодировал его почти так же, как stackoverflow. Я построил на кнопке, уже созданной @Reigel.

Надеюсь, это поможет. Ура :)

РЕДАКТИРОВАТЬ : Здесь также добавлен ответ от jsFiddle по запросу.

HTML:

<a href="#" class="post-tag" title="show questions tagged 'mousehover'" rel="tag">Ruby-on-Rails</a>

<a href="#" class="post-tag" title="show questions tagged 'mousehover'" rel="tag">JQuery</a>

<a href="#" class="post-tag" title="show questions tagged 'mousehover'" rel="tag">CSS</a>


<div class="mouseoverHoverBox">
    <span class="pointer">
        <span class="plusminus">+</span>
        <span class="addRemove">Add </span>
        <span class="insert"></span>
        <span class="fromTo"> To </span>
        <span>Interesting tags</span>
    </span>
    <br />
    <span class="pointer">
        <span class="plusminus">+</span>
        <span class="addRemove">Add</span>
        <span class="insert"></span>
        <span class="fromTo"> To </span>
        <span>Ignored tags</span>
    </span>
</div>

CSS:

.post-tag {
    position:relative;
    background-color: #E0EAF1;
    border-bottom: 1px solid #3E6D8E;
    border-right: 1px solid #7F9FB6;
    color: #3E6D8E;
    font-size: 90%;
    line-height: 2.4;
    margin: 2px 0px 2px 0px;
    padding: 3px 4px;
    text-decoration: none;
    white-space: nowrap;
    }

.post-tag:hover {
    position:relative;
    background-color:#3E6D8E;
    color:#E0EAF1;
    border-bottom:1px solid #37607D;
    border-right:1px solid #37607D;
    text-decoration:none;
}

.mouseoverHoverBox {
    position:relative;
    top: -6px;
    border: 2px ridge #CCC;
    padding: 10px;
    width: 250px;
}

.plusminus {
    color: #E45C0E;
}

.pointer {
    cursor: pointer;
    width: 100%;
    height: 100%;
    color: #3E6D8E;
}

JAVASCRIPT:

$('.mouseoverHoverBox').hide();

$('.post-tag').live('mouseover',function(e){
    var x = $(this).offset();
    $('.mouseoverHoverBox').css('left',x.left-10);
    $('.insert').html(' <b>'+$(this).text() + '</b> ');
    $('.mouseoverHoverBox').slideDown();
});

$('.pointer').live('mouseover mouseout', function(e){
    if(e.type=="mouseover") {
        $(this).css('text-decoration','underline');
    }else if(e.type="mouseout") {
        $(this).css('text-decoration','none');
    }
});

$('.pointer').toggle(function() {
   $(this).find('.plusminus').text('x ');
   $(this).find('.addRemove').text('Remove ');
   $(this).find('.fromTo').text('From');
}, function() {
   $(this).find('.plusminus').text('+ ');
   $(this).find('.addRemove').text('Add ');
   $(this).find('.fromTo').text('To');
});

$('.mouseoverHoverBox').mouseleave(function(){
     $(this).hide();
});
23
ответ дан 3 December 2019 в 17:19
поделиться

Я согласен с обоими, просто чтобы подчеркнуть, вы абсолютно точно можете использовать :hover в CSS, если вы нацелены на браузеры новее IE6, IE6 не будет работать с :hover, если это не ссылка.

-1
ответ дан 3 December 2019 в 17:19
поделиться

Для простого эффекта наведения вам действительно следует использовать css , например

a.hover:hover {
   background-color: #ff0000;
}

.

Если он должен находиться в jQuery, он будет выглядеть как

$('a.myanchorclass').hover(function(){
     $(this).css('background-color', '#ff0000');
}, function(){
     $(this).css('background-color', '#000000');
});
1
ответ дан 3 December 2019 в 17:19
поделиться
Другие вопросы по тегам:

Похожие вопросы: