- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
您会注意到站点 testing.ksischool.com 的主导航区域( Logo 下方的灰色条)中的链接的 :hover CSS 在 Firefox 中工作正常,但 IE7 砍掉了底部的几个填充像素。为什么?
最佳答案
我假设您在谈论顶部导航;你正在填充一个内联元素(<a>
标签)。当在内联元素上放置 padding 时,水平 padding 会插入其他元素,但垂直 padding 只会增加元素的大小而不会影响它周围的布局。可能 Firefox 在源代码中将框呈现在它们下方的元素上方,但无论出于何种原因,IE 将它们呈现在下方,这就是为什么您会看到部分框消失的原因。
要解决此问题,请将所有链接向左浮动(这实际上将它们变成了 block 元素)。您需要在别处调整您的标记以使其工作(如果您只是直接 float ,可能会出现一些清除问题),但这应该可以解决特定的 IE 问题。
编辑更多细节:
如上所述,内联元素上的垂直内边距并不像您预期的那样表现(它增加了元素的高度,但由于内边距不与其他页面元素交互,内联元素经常以奇怪的方式重叠事物).因此,要解决此问题,您需要以某种方式使填充元素(<a>
标记)具有 display: block
。 .为了让所有东西都在同一条线上,向左浮动是你最好的选择。这是我将使用的标记和样式:
<style type="text/css">
.mainnav {
font-size: 1em;
color: #999;
list-style-type: none;
/* zoom triggers hasLayout on IE, ignored by others
Necessary for the clearfix */
zoom: 1;
}
.mainnav:after {
/* This lets the .mainnav auto-clear its floated contents */
content: ".";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
.mainnav li {
float: left;
margin: 0 2px;
/* Place background (disc image) here w/ appropriate padding */
}
.mainnav li.last {
background: none;
}
.mainnav a:link, .mainnav a:visited {
display: block;
color: #fff;
text-decoration: none;
padding: 1px 1px 2px;
border: solid 1px transparent;
}
.mainnav a:hover {
color: #fff;
background: #999;
text-decoration: none;
padding: 1px 1px 2px;
border: solid 1px #ccc;
}
.mainnav a.selected, .mainnav a.selected:hover {
color: #B59B24;
background: transparent;
text-decoration: none;
}
</style>
<ul class="mainnav">
<li><a href="/" class='selected'>Home</a></li>
<li><a href="/About" >About</a></li>
<li><a href="/Admissions" >Admissions</a></li>
<li><a href="/Curriculum" >Curriculum</a></li>
<li><a href="/Home/VacancyList" >Careers</a></li>
<li class="last"><a href="/Contact" >Contact</a></li>
</ul>
需要注意的一些事项:我正在使用标准的 clearfix(如果您不知道我在说什么,请谷歌搜索)以确保 UL 清除其 float 内容。如果用户放大字体,这将允许父导航元素的大小适当增加。
此外,我删除了垫片 ·
并推荐使用背景图片和 .last
CSS 中的类。这纯粹是个人喜好。 (在理想情况下,您会使用 :after 伪类来注入(inject) ·
,但由于 IE 6 不支持它,您不能这样做并支持所有浏览器。)我推荐背景图片的原因与其将它留在标记中,还不如将它留在标记中,这样可以使标记更清晰,并且更容易在以后进行更改(比如说,如果您的客户决定他们想要管道而不是点)。
此标记/样式背后的逻辑是您需要在 <a>
上填充要使边框/背景颜色起作用,这意味着它必须有 display: block
.但是,添加它会将每个链接都放在不同的行上,因此您需要 float 它或它的父级。因为它是列表的一部分,所以 float li
更容易parent 并使用 clearfix 来确保 ul
页面上仍有一些存在。
显然,如果您使用此代码,则需要删除大部分 #nav_banner element
样式表中的内容较低,您可能需要再次调试跨浏览器。即使您不会,也希望它能为您提供一些想法,以便将来轻松构建顶部导航。
关于css - 为什么我的 CSS 在 IE 中呈现错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/523243/
我是网页设计新手。现在我遇到了我目前工作的 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 中出现了一些错误。即使出现几个错误,应用程序仍然可以顺利运行,没有明显的问题。 我想对
我是一名优秀的程序员,十分优秀!