- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我想知道是否有人遇到过这个问题,他们是如何解决的。IE 没有为我在运行时添加的类应用样式 (jQuery)。奇怪的是,开发人员工具显示应该应用它。见下图。
“fa-bars”元素有一个带有“blue”类的父元素。在本例中,我在 $(document).ready() 中添加了“blue”类。如果我在 HTML 标记上添加“蓝色”类(而不是在运行时添加),它会正确应用样式。但这不是我想做的。
我只在 IE 上遇到这个问题(我使用 IE8),但 Chrome 和 FF 都按照我的预期(正确)呈现页面。关于如何解决这个问题的任何想法?
似乎只有在呈现伪内容(例如 FontAwesome)时才会出现问题。如果我用纯文本替换该元素,它就可以工作。
已添加:
这是我的完整 HTML,其中包含指向 FontAwesome 和 jQuery 的 CDN 的链接:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width" />
<title>Test</title>
<link href="http://netdna.bootstrapcdn.com/font-awesome/4.0.3/css/font-awesome.css" rel="stylesheet">
<script src="http://code.jquery.com/jquery-1.10.2.min.js" type="text/javascript"></script>
<script type="text/javascript">
$(document).ready(function () {
$('.nav-toc').addClass('blue');
});
</script>
<style type="text/css">
.fa {font-size: 1.5em;}
.nav-toc {color: red;}
.blue {color: blue;}
</style>
</head>
<body class="pson-green">
<div id="master-body">
<!-- Top banner (Menu) -->
<div id="master-header">
<div class="content-wrapper">
<div id="nav-grp-toc" class="nav-container">
<div class="nav-btn nav-toc" title="Contents Menu"><i class="fa fa-bars"></i></div>
</div><div id="nav-grp-help" class="nav-container">
<div class="nav-btn nav-help" title="Help"><i class="fa fa-question"></i></div>
</div><div id="nav-grp-counters" class="nav-container">
<div id="page-counter" class="nav-page counter-panel">
<div id="current-page" class="current-count" title="Current page number"></div>
<div id="total-pages" class="max-count" title="Total number of pages"></div>
</div>
<div id="question-counter" class="nav-quiz counter-panel">
<div id="current-question" class="current-count" class="Current question number"></div>
<div id="total-questions" class="max-count" title="Total number of questions"></div>
</div>
</div><div id="nav-grp-steppers" class="nav-container">
<div class="nav-btn nav-page nav-prev" title="Back"><i class="fa fa-chevron-left"></i></div>
<div class="nav-btn nav-page nav-next" title="Next"><i class="fa fa-chevron-right"></i></div>
</div><div id="nav-grp-exit" class="nav-container">
<div class="nav-btn nav-page nav-exit" title="Exit Course"><i class="fa fa-sign-out"></i></div>
</div>
</div>
<div id="dimmer-for-header" class="dimmer"></div>
</div>
</div>
</body>
</html>
最佳答案
我想我可能已经找到了答案。从我对类似帖子的搜索看来,问题出在 IE 对伪元素的处理上。不幸的是,我对这些帖子的许多答案/建议似乎对我的情况不起作用,除了这个 SO item .基本上,它建议强制 IE 重新绘制伪元素,方法是临时向 DOM 添加一个删除所有伪内容的样式标签,然后立即删除该样式标签。当结合基于此 SO item 的 IE8 检查时,它似乎有效。 .我将此添加到我的脚本中:
var ie = (function () {
var undef,
v = 3,
div = document.createElement('div'),
all = div.getElementsByTagName('i');
while (
div.innerHTML = '<!--[if gt IE ' + (++v) + ']><i></i><![endif]-->',
all[0]
);
return v > 4 ? v : undef;
} ());
function redrawPseudos() {
var head = document.getElementsByTagName('head')[0],
style = document.createElement('style');
style.type = 'text/css';
style.styleSheet.cssText = ':before,:after{content:none !important;}';
head.appendChild(style);
setTimeout(function () {
head.removeChild(style);
}, 0);
}
所以当我必须添加/删除一个类时,我希望它会影响伪元素的样式,我必须这样做:
$('.class1').addClass('newclass');
if (ie === 8) {
redrawPseudos();
}
这可能是一种昂贵的方式。但是我只有不到十几个伪元素。
已添加:
您可以通过将选择器传递给 redrawPseudos() 并将其包含到样式中来改进这一点。这会将重绘限制为由您的选择器标识的元素。
function redrawPseudos(sel) {
...
style.styleSheet.cssText = sel + ':before, ' + sel + ':after, ' + sel + ' *:before, ' + sel + ' *:after ' + '{content:none !important;}';
...
}
关于css - IE8 不应用该样式,即使它的开发人员工具显示它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21470482/
我是网页设计新手。现在我遇到了我目前工作的 2 个网站的问题。我的模板只支持 Firefox 浏览器,不支持其他主流浏览器,如 IE、chrome、Opera、safari。 我试过一些 If IE
在我的 HTML 上,使用了下面的元标记来解决一些字体问题。我只想知道: 这两个元标记的含义相同吗?还是每一个都不一样? [以逗号分隔] [以分号分隔] 请解释一下。 最佳答案 Microsoft
这句话究竟是什么意思? 部分示例使用 ,分隔 IE 的版本,而有些使用 ; ;哪个是正确的? 订单IE=9; IE=8; IE=7; IE=EDGE有一些重要性,我想知道。 编辑:我正在使用 最佳答
这句话究竟是什么意思? 一些示例使用 ,分隔 IE 的版本,而有些使用 ; ;哪个是正确的? 订单IE=9; IE=8; IE=7; IE=EDGE有一定的重要性,我想知道。 编辑:我正在使用 最佳
在 IE 8 中,我们可以带出开发者工具。然后在顶部,有一个浏览器模式: IE 7 IE 8 IE 8 Compatibility View 所以如果 IE 7是强制页面显示为好像浏览器是 IE 7,
我认为不需要任何描述。我只需要我的 IE 11 单选按钮与 IE 8 中的一样,即颜色为 3-d 蓝色。在 IE 11 中,默认单选按钮是二维的,颜色为黑色。目前还没有解决这个问题。 最佳答案 检查这
我必须编写一个显示密码对话框的小程序。问题是对话框设置为始终在顶部,但是当用户单击 IE 窗口时,对话框仍然隐藏在 IE 窗口后面。并且由于对话框是模态的并且保持全部 IE 线程 IE Pane 不会
如何制作适用于所有 IE 浏览器的样式表。不只是 ie.css 中的 IE 8 本站主题的ie.css文件中只包含IE8样式。 最佳答案 他们这样做的原因是因为他们可能不支持 Internet Exp
使用有什么区别吗 ... 或者 ... ? 最佳答案 如果一种罕见的、神话般的浏览器被称为 ,就会有所不同。 Internet Explorer 6.66 被发现。 关于internet-explor
我试图在 IE7+8 中使用字体图标并遇到了一个问题,这个问题可以通过仅 IE7 的样式表轻松解决。长话短说,现在 IE7 和 IE9 都以某种方式运行我的仅 IE7 样式表(IE8 运行得很好)。我
我实现了上传的图片显示在网站上。为了 图片未正确上传意味着我将错误图片替换为 那?当我加载网站时,我遇到了 错误图像不存在的问题 定义,并且灯箱在 chrome 和 firefox 中加载 但它没有在
我有一个特殊的问题。我正在尝试“现代化”和为旧 IE 制作的旧应用程序,以便在 IE 11 中工作。但不知何故,CSS 类没有应用于 DOM 元素。 CSS 非常简单: .header { h
对于 IE 7 和 IE 8,IE 上 URL 的 2k 长度限制是否仍然存在? (后 IE 6 时代) 最佳答案 http://support.microsoft.com/kb/208427 似乎它
我们正在完善这个网站:dev.underglassframing.com 除了主要内容 div (#main) 后面的背景在 IE 7、8 和 9 中的内容之前停止外,在每个浏览器中一切都很好。我在末
我在 IE 11 中搜索过与 border-radius 相关的类似问题,但是 only one found on the Microsoft IE Developer site描述了自从“升级”到
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit th
这个问题在这里已经有了答案: (CSS?) Eliminating browser's 'selected' lines around a hyperlinked image? (5 个答案) 关闭
我知道有 1000 个问题,但我就是无法让它发挥作用。我只是想针对所有版本的 IE(包括 IE11)并给 html 一个特定的类,对于所有其他浏览器(firefox、opera、chrome),我希望
我有一个嵌入了 Internet Explorer 的程序。 在某些情况下,我需要调整嵌入式 IE 的缩放级别。我正在使用带有 OLECMDID_OPTICAL_ZOOM 的 ExecWB 命令来执行
我正在开发一个网络应用程序。我的应用程序在 chrome 和 firefox 上运行良好,但由于某种原因在 IE 中出现了一些错误。即使出现几个错误,应用程序仍然可以顺利运行,没有明显的问题。 我想对
我是一名优秀的程序员,十分优秀!