[英]querySelectorAll ":not" doesn't work in IE8, does jQuery's version?
[英]jQuery's closest doesn't work in IE8/9
我有这个jQuery代码:
$(this).closest('div:has(.FIND_ME)').find('.FIND_ME').hide();
但是具有类.FIND_ME
元素不会隐藏在IE8和9中。
此问题是搜索具有共同祖先的项目的延续
HTML:
<div>
<div><!-- all div without ID -->
<span>some text</span>
<div>
<span id="listener1">click here</span>
<span>sometext</span></div>
<div>
<span class="FIND_ME">Result Here</span></div>
</div>
<div>
<span>some text</span>
<div id="div1">
<div id="div2">
<span id="listener2">click here</span>
<span>sometext</span></div>
</div>
<div>
<span class="FIND_ME">Result Here</span></div>
</div>
</div>
我是一个变量设置element
来this
,再后来我打电话:
element.closest('a')
但是element现在是DOM元素而不是jQuery对象。 所以改为:
$(element).closest('a')
修复。
你是对的! 我不知道为什么,但它现在有效! 错误发生在另一个地方。
因此, closest()
在IE 8/9中运行良好。 在jQuery 1.6上测试过。
closest = function (target, tag) {
if (target.parentElement == "undefined") {
return null;
}
if (target.parentElement.localName == tag) {
return target.parentElement;
}
return this.closest(target.parentElement, tag);
};
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.