- objective-c - iOS 5 : Can you override UIAppearance customisations in specific classes?
- iphone - 如何将 CGFontRef 转换为 UIFont?
- ios - 以编程方式关闭标记的信息窗口 google maps iOS
- ios - Xcode 5 - 尝试验证存档时出现 "No application records were found"
HTML:
<p>Hover</p>
CSS:
p::after {
content: " here";
transition: all 1s;
}
p:hover::after {
font-size: 200%;
color: red;
}
现场演示: http://jsfiddle.net/SPHzj/13/ (适用于 Firefox 和 Chrome)
如您所见,我已经在段落的 ::after
伪元素上设置了 CSS 转换。然后,当段落悬停时,两个新样式应用于过渡的伪元素。
这适用于 Firefox 和 Chrome,但不适用于 IE10。我的理由是 IE 不理解 p:hover::after
选择器,因为如果您将鼠标悬停在祖先元素上,它在 IE 中工作,例如div:hover p::after
- 现场演示:http://jsfiddle.net/SPHzj/14/ .
然而,事实并非如此,因为 IE 确实能够理解该选择器。诀窍是还要定义一个 p:hover {}
规则。 (由 @maxw3st 发现。)
p:hover {}
这条规则可以为空。仅此规则的存在将使过渡在 IE10 中起作用。
现场演示: http://jsfiddle.net/SPHzj/15/ (也适用于 IE10)
这是怎么回事?为什么 IE 要求存在该规则才能使转换在伪元素上起作用?这应该被视为错误吗?
最佳答案
这似乎是 Internet Explorer 10 中的合理回归。如 on MSDN 所示,因为 Internet Explorer 7 用户已经能够定位任何元素的悬停状态,而不仅仅是a
。
奇怪的是,我尝试了 :active
伪类,这似乎按预期工作。进一步确定这是一个回归,您可以看到通过将其更改为 a
元素,转换按预期发生(因为历史上,a
和 :悬停
携手并进)。
目前我只能想到几个解决方案(在等待修复此问题时):
p:hover {}
修复。p
的子级上的 ::after
。第一项是您在问题中指定的内容,并且由于其简单性而非常有吸引力。事实上,您可以使用 :hover{}
并获得相同的结果 (probably the best solution)。
第二项也是可行,但不太理想,因为它需要修改标记,这并不总是可行的,坦率地说,有点傻。
最后一个选项有点有趣。如果您将选择器修改为基于兄弟关系,它会神奇地再次开始工作。例如,假设我们在正文中有多个元素:
<h1>Hello, World</h1>
<p>This is my first paragraph. it does not animate.</p>
<p>This animates, with a pseudo-element.</p>
我们现在可以使用组合器来定位第二段:
p+p:hover::after {}
虽然这个选择器将匹配段落之后的任何段落,但这是不可取的。此时我们可以考虑 :nth-child
或 :nth-of-type
来进一步指定我们想要的段落,甚至可以使用通用的兄弟组合器:
h1~p:nth-of-type(2):hover::after {} /* Targets second <p> nearest <h1> */
但更理想的情况是,我们将以类为目标:
h1~.hoverme:hover::after {} /* Targets <p class="hoverme"> */
更进一步,也许您不希望被明确提供通用同级标记所锁定。您还可以使用通用选择器:
*~.hoverme:hover::after {} /* Targets <p class="hoverme"> among siblings */
这要求 p
标签有 sibling ,这通常是预期的。文档很少只包含一个段落标记。
我知道这些并不理想,但它们是目前达到目的的一种手段。我们希望在未来的 Internet Explorer 版本中看到这个问题得到解决。
关于css - 为什么 IE10 要求存在 p :hover {} rule for transitions to work on a pseudo element?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16015371/
我有一个类和构造函数,如下所示: def init(log, edge): if edge: return Helper(log, edge) return Booka
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
有人知道在 mongo 上安装标准 ubuntu 需要多少磁盘空间和内存吗?试图找出我的 VPS 需求... 最佳答案 没有最低要求,但我不建议在与您的网络服务器相同的机器上运行 Mongo。 Mon
我的 Django 项目有一个虚拟环境,但是当我 pip 击 pip freeze 时,我得到了一个必须是全局站 pip 包列表的东西,包括太多包,比如ubuntu包和这么多不相关的东西。无论 vir
我曾尝试在 Heroku 上部署我的应用程序,但 smth 出错了。 错误:找不到满足要求的版本 get==2019.4.13(来自 -r/tmp/build_53ad6d03_/requiremen
我无法将 semantic-ui-calendar npm 模块加载到我的应用程序中。 我已经使用脚本标签成功地将它加载到我的 HTML 中, 但每次我尝试将它加载到我的应用程序中时,我都会出错。 在
如何修复 php.ini 中“require”函数内的地址?它进行故障排除并显示错误: 警告:require (..) 无法打开流:没有这样的文件或目录。 文件“db_connection.php”工
我有一个在 Node.js 应用程序中使用的外部库 ( Objection.js )。我创建了一个基本模型类,它为我的实体模型扩展了 Objection 的 Model 类: const { Mode
有谁知道在哪里可以找到RHEL5的GLIBC2.7,如果没有这个,Android模拟器将无法启动。它会给出一条消息,要求GLIBC 2.7或更高版本。 我尝试在网上搜索,但没有找到 最佳答案 我也遇到
Android 设备是否有任何要求/指南?例如按钮数量或所需的最少按钮数量。 还有没有菜单和后退按钮的安卓设备吗? (我知道就可用性而言,没有菜单/后退按钮会杀死大多数应用程序,我只是想了解更多有关该
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我正在尝试在我的 Linux Mint 发行版上安装一个 python 模块“pyAudioProcessing”(https://github.com/jsingh811/pyAudioProces
我已经创建了我的第一个 composer 包,它具有 MySQL 和 MongoDB 的功能,但是,它不需要两者。我意识到有人可能只想将这个包与两个数据库之一一起使用,目前我有: "require":
我想调试以下函数,但假设在调试器中查看 moreajaj 的参数等于什么(假设不像在这个人为的示例中那么明显)是有用的。我可以在调试器框架中打印它,但是在每个参数的每个框架中都这样做很烦人。在宣布每一
我有一些生成的 GNUmakefiles,我需要从中提取变量的值。 有没有一种简单的方法可以在不修改 makefile 的情况下查看变量的值? 仅供引用,变量包含 emacs c-macro-expa
我正在使用 aspell 在 Linux 上拼写检查 LaTeX 文档。我的文档经常包含各种编程语言的代码示例,我希望 aspell 在拼写检查时简单地跳过这些行。 我可以在文档中写些什么来关闭一段文
我有一个包含多个列的数据集... 一列是具有重复值的主石斑鱼列,另一列是具有 bool 值 (1,0) 的 NUMBER,如下所示: grp bool --- ---- A 1 A 1 A
出于测试目的,我正在尝试删除一些 amd 模块并从服务器重新加载更新版本 - 目的是不刷新浏览器。 我目前正在执行以下操作,但浏览器仍然没有从网络重新加载项目。 var scripts = docum
当我键入irb> require 'rubygems'时,它返回false。我的Rails应用程序中有很多 gem ,这些 gem 显然可以正常工作-耙子,activerecord等。这里可能出什么问
我是一名优秀的程序员,十分优秀!