javascript - jQuery on list item hover, show delete button for that individual item - Stack Overflow

Below is a preview of what I have:On the right is when I hover.What I want is for the delete icon to

Below is a preview of what I have:



On the right is when I hover. What I want is for the delete icon to only show for that hover item.

<script>
$(document).ready(function(){ 

    $(".removeService").hide();     

    // Deleting an Individual Service
    $("#dashboard ul li span").hover( function() {
        $(".removeService").show();
    });

});
</script>

This is probably a very simple fix, but if anyone could point me in the right direction I would really appreciate it.

Thanks!

Below is a preview of what I have:



On the right is when I hover. What I want is for the delete icon to only show for that hover item.

<script>
$(document).ready(function(){ 

    $(".removeService").hide();     

    // Deleting an Individual Service
    $("#dashboard ul li span").hover( function() {
        $(".removeService").show();
    });

});
</script>

This is probably a very simple fix, but if anyone could point me in the right direction I would really appreciate it.

Thanks!

Share Improve this question asked Jan 13, 2012 at 20:21 DrewDrew 6,87219 gold badges65 silver badges97 bronze badges
Add a ment  | 

4 Answers 4

Reset to default 6

If you want the delete span to show only when hovered over and hidden when the mouse exits, you can use an 'overload' for the .hover() function by providing a second function that hides the delete span.

See this fiddle here for an example.

A very simplified example could look like this:

$(document).ready(function(){
    $('.remoteService').hide()
        .click(function(){alert('delete!');});

    $('#dashboard ul li span').hover(
    function(){  //this is fired when the mouse hovers over
        $(this).find('.remoteService').show();
    },
    function(){  //this is fired when the mouse hovers out
         $(this).find('.remoteService').hide();
    });

});

I hope this helps!

<script>
$(document).ready(function(){ 

    $(".removeService").hide();     

    // Deleting an Individual Service
    $("#dashboard ul li span").hover( function() {
        $(this).find(".removeService").show();
    });

});
</script>

This assumes that .removeService is nested within #dashboard ul li span. If this is not the case, please provide your html.

In the code this is the actual span which is hovered on. find will search within that span for all elements with the removeService class.

Edit:

Used image tag instead of background-image(see DEMO link at the bottom) to make it click-able.

DEMO here.


Why not use CSS :hover to get the same effect.

DEMO here

You have to do this with jQuery, you can achieve the same behavior with pure CSS:

#dashboard ul li .removeService {
    display: none;
} 

#dashboard ul li:hover .removeService {
    display: inline;
} 

Example on jsfiddle

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1743633560a4481772.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信