繁体   English   中英

jQuery .is(“:hover”)在IE8中

[英]jQuery .is(“:hover”) In IE8

我在检查IE8中div的状态时遇到问题。 我想检查鼠标当前是否悬停在某些div上。 目前在IE8中,我收到以下错误: Syntax error, unrecognized expression: hover 下面是导致错误的jQuery:

// This function will close the slideout of widgets
function CloseWidgetPanel()
{
    if (!$("#widgets").is(":hover") && !$(".widgetPanel").is(":hover"))
    {
        if ($("#widgets").is(":animated"))
        {
            $("#widgets").stop(true, true);
        }
        $("#widgets").hide("slide", { direction: "right" }, 300);
    }
    else
    {
        // We are currently hovering over a panel, so check back in 2 seconds.
        setTimeout(CloseWidgetPanel, 2000);
    }
}

替代方式:

$(".widgetPanel, #widgets").hover(function() {
    $(this).toggleClass('hover')
});

然后:

if (!$("#widgets").is(":hover") && !$(".widgetPanel").is(":hover"))

change to

if (!$("#widgets").hasClass('hover') && !$(".widgetPanel").hasClass('hover'))

jQuery没有实现:hover选择器和IE8不支持queryselectorall ,因此它失败了。 您必须找到另一种方法来检测当前正在悬停的元素,例如mouseenter和leave事件,该事件设置全局(或父范围)变量或将状态类/属性应用于元素。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM