jQuery css() function changing 'a' property not 'a:hover' property

前端 未结 5 822
小蘑菇
小蘑菇 2021-01-05 05:49

I\'m having a bit of trouble with the jQuery css() function at the moment. It is changing the css value of the anchor element\'s border-top-color i

相关标签:
5条回答
  • 2021-01-05 06:16

    The reason it doesn't work is because the :hover bit doesn't actually give the selector any information about an element.

    a:hover in CSS matches on the same exact elements as a, it's just defining a different set of properties for when the user is hovering over those elements.

    The jQuery selector is designed to find (select) elements, not to style them.

    The css() method simply sets an inline style on the elements that are selected, it does not add or change any actual CSS declarations.

    As other have mentioned, you can use the hover() event to get the same behavior. Although, adding a class on the fly is probably better, as another answerer described.

    However, if you don't need to make it change on-the-fly, I recommend using plain old CSS since it is faster and does not require a user to have javascript enabled.

    0 讨论(0)
  • 2021-01-05 06:17

    This code is broken since 1.9

    if($('...').is(':hover')){
      $(this).css('set','your styles here')
    }
    

    use this instead

    var class = '...';
    if($(class+':hover').length>0){
      $(class).css('set','your styles here');
    }
    
    0 讨论(0)
  • 2021-01-05 06:31

    I don't know exactly why, but this type of changes are better done in CSS, so I'd suggest that, if you really need to change this through JS, create a CSS class, then change that in JS.

    CSS

    #header #headerlist li a.fancy-border:hover{
      border-top-color: rgb(225, 149, 79);
    }
    

    JS

    $("#header #headerlist li a").addClass("fancy-border");
    

    That way you can better separate functionality from presentation.

    0 讨论(0)
  • 2021-01-05 06:35

    The reason your example doesn't work is because the selector has no way of detecting :hover since that's a pure CSS thing. Instead you might try using the actual jquery hover method:

    $("#header #headerlist li a").hover(
      function () {
        $(this).css("border-top-color", "#FF0000");
      }, 
      function () {
        $(this).css("border-top-color", "#000000");
      }
    );
    

    Alternatively, you could also use the addclass method as well:

    $("#header #headerlist li a").hover(
      function () {
        $(this).addClass('hover-highlight');
      }, 
      function () {
        $(this).removeClass('hover-highlight');
      }
    );
    

    This could be further simplified to:

    $("#header #headerlist li a").hover(function () {
        $(this).toggleClass('hover-highlight');
    });
    
    0 讨论(0)
  • 2021-01-05 06:39

    add !important to the hover css to avoid the style is overrided. for example:

    test:hover {
        border: 1.5px solid white !important;
        color: white !important;
    }

    0 讨论(0)
提交回复
热议问题