- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
IE 有一个问题,即 :hover
伪类在打开 select
元素时无法按预期工作。一旦打开下拉菜单并将鼠标移到选项上,所有父标签就会松开 :hover
伪类。
这是因为打开的下拉菜单是作为新窗口实现的 (source)
我正在尝试通过在父元素上使用 mouseenter
和 mouseleave
事件来使用 Javascript 修复此问题,但是,不幸的是,mouseleave
也是当用户将鼠标移到打开的下拉菜单上时引发。
到目前为止我的尝试:
var container = document.getElementById("container");
var select = document.getElementById("select");
//$('#select').select2();
container.addEventListener("mouseenter", function() {
container.classList.add("hover");
});
container.addEventListener("mouseleave", function() {
container.classList.remove("hover");
});
#container {
display: inline-block;
background-color: red;
}
#container:hover,
#container.hover {
background-color: green;
}
<div id="container">
<select id="select">
<option>Some option 1</option>
<option>Some option 2</option>
<option>Some option 3</option>
</select>
<p>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
some long text text text text text<br>
</p>
</div>
最佳答案
无论出于何种原因,在 IE11 中,mouseleave 事件都会在您的鼠标经过选择时触发(即使它包含在您正在监听的父 div 中)。尝试检查事件的“relatedTarget”属性,看看您是否正在“离开”后代的 div,或者您是否真的正在离开 div:
container.addEventListener("mouseleave", function(e) {
if (e.relatedTarget && !container.contains(e.relatedTarget)) {
container.classList.remove("hover");
}
});
基本上,仅当我们要移动到的元素 1) 存在且 2) 不是我们容器的后代时才删除“悬停”类。
关于“relatedTarget”:https://www.w3schools.com/jsref/event_relatedtarget.asp
好处:“relatedTarget”与所有主流浏览器兼容。
编辑:我们在查看“e.relatedTarget”是否包含在容器中之前检查它的原因(没有双关语意)是因为“relatedTarget”可能为空。事实上,当您将鼠标悬停在选择下拉列表上时,“relatedTarget”始终为 null。我很想知道为什么会这样,而不是在离开 HTML 主体的 div 时触发“mouseleave”,在那里您确实获得了“relatedTarget”的元素。
关于javascript - 修复 :hover pseudo class in IE11,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46475363/
我已经为我的项目配置了 tailwindcss,但是在 npm run start 之后我得到了以下错误。 (node:7032) UnhandledPromiseRejectionWarning:错
我使用 create-react-app 创建了一个应用程序并且在尝试构建生产优化版本时遇到错误 yarn build : > yarn build help yarn run v1.9.4 $ re
我正在寻找一种将 :content 伪元素添加到空元素的方法,并遇到了 :empty CSS 伪选择器,它看起来像会达到我正在寻找的目的。基本上,我想添加一个通用消息,如“Nothing found”
Font Awesome 未提供 :after伪。是否可以使用 :after默认情况下而不是 :before伪? 例如,如果我使用:facebook那么图标应该使用:after而不是 :before
我想在禁用时更改切换按钮的颜色。我使用 :before fetaure of css 实现了这个切换。代码位于 https://jsfiddle.net/sachin8085/adm5t7rz/6/
我最近在 Firefox 中发现了一个警告 Warning: Unknown pseudo-class or pseudo-element 'hidden' 这是页面 http://eleven23.
我有一个多项式 data Poly a = Poly [a] 我希望能够做类似 fmap (take 3) polynomial 的事情但我不能,因为 Poly不是真正的仿函数,因为 f我在 fmap
我想将某种样式应用到一个元素的所有后代,除了一些。 这是我正在尝试实现的示例:http://jsfiddle.net/f8FLe/ .root * :not(.nested) { color:
我正在学习 Haskell 中的代数 DT。我想做的是创建一个新的 ADT 来“扩展”现有的 ADT。我找不到如何表达我想要的东西,有人可以建议替代模式或建议解决方案。我希望它们是不同的类型,但复制和
我现在正在通过将所有内容包含在一个函数中,将全局变量变成“伪全局变量”,从而从我的代码中删除大部分全局变量,这些全局变量都可以从该函数 block 内的任何地方访问。 (function(){ var
我正在尝试创建动画时间轴。当时间轴出现时,我正在使用滚动显示来触发动画。每个时间线条目都有一个左边框和一个伪元素 :before 与之关联。 :before 元素是一个标记每个时间线条目开始的点。当动
我的大脑并没有完全围绕这个:我正在使用我的 h1 上的 :before 和 :after 伪元素>。我的 h1 有一个 100% 宽度。 我希望 :after 是一个重复的背景图形,填充空白,后置文本
是否可以在 :before 伪类的内容中添加类或 ID?我知道这行不通,但是类似: #menu { height: 100px; width: 100px; } #menu:befor
假设我有一个带有下划线的跨度: Hello, I'm underlined text .underline { color: #444; font-size: 250%; display:
这个问题在这里已经有了答案: CSS selector with period in ID (3 个答案) 关闭 6 年前。
我正在尝试将 :after 伪元素移动到 div 的末尾,有点像页脚。 Some content here .box { height: 60vh; } .box:after {
在您指定内容之后,:AFTER 和:BEFORE 伪元素的默认display: 属性是什么。 是display: inline还是display: inline-block? 无法在 default
我遇到这样一种情况,我有两个元素在 DOM(邻居)中处于同一级别。当我悬停在 DOM 中之前的元素时,我希望显示它下面的元素。我还想访问我正在显示的元素的子元素并显示其 :before 伪元素。 SC
我有一个样式规则: .tabs li { border: 1px solid transparent; } .tabs li:not(:last-child):not(:nth-child(2
我有两个相同的 CSS 规则,但一个没有覆盖另一个。 我使用了 right 而不是 left 规则,但它不会覆盖 left 规则。另一方面 top 规则正在覆盖。我也使用了 !important 规则
我是一名优秀的程序员,十分优秀!