- 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"
我有一个基本菜单,由水平对齐的列表 ( <li>
) 组成,每个菜单包含一个图标图像和一些文本:
<li>
之一包含带有 display: none;
的额外图像这样就可以切换图标(在本例中,从绿色到红色辣椒。问题是它在某些浏览器上没有正确对齐,如上图所示。我的理解是,与 visibilty: hidden;
相比, 一个带有 display: none;
的元素不应该影响任何其他元素的位置并且应该像不存在一样呈现?
无法正确呈现的浏览器是 Google Chrome 和 Safari - 但仅限于 MacOS(!?) 和 IE7(我知道,我知道...)在 Windows 上。我测试过的所有其他浏览器/操作系统组合都可以正常工作。
这是 HTML:
<ul class="menu">
<li><img alt="Green Pepper" src="/green.png">li</li>
<li><img alt="Green Pepper" src="/green.png">li</li>
<li><img alt="Green Pepper" src="/green.png">li</li>
<li id="change">
<img alt="Red Pepper" src="/red.png" style="display: none;">
<img alt="Green Pepper" src="/green.png">
li
</li>
<li><img alt="Green Pepper" src="/green.png">li</li>
</ul>
这是 CSS:
.menu li {
cursor: default;
font-family: Verdana, Arial, Helvetica, sans-serif;
font-size: 10pt;
list-style-type: none;
position: relative;
text-align:center;
margin: 0 0 0 -25px;
padding: 8px 0 0 0;
width: 144px;
height: 35px;
display: inline-block;
background-image: url(../bct-white.png);
background-repeat: no-repeat;
color: #0091c1;
}
对于图标图像:
.menu img {
display: inline;
vertical-align: -25%;
padding-right: 6px;
}
我还必须包括一个针对 IE7 的浏览器 hack,因为它无法识别内联 block ,来自基于条件导入 (<!--[if lte IE 7]>
) 的单独样式表:
.menu li {
zoom: 1;
display: inline;
}
不过,显然无论操作系统如何,该样式都不会在 Chrome 和 Safari 上加载,因此不会导致我在 Mac 上出现问题。
我知道最快的解决方案是重构 HTML 和图标显示/隐藏的 JavaScript 操作,但我真的很想知道导致此问题的原因以及如何解决它。
更新
我已经找到原因了。基本上,display: none;
的元素样式在 <img>
上元素覆盖 inline
来自 .menu img
规则。删除它,然后在 block
之间切换和 inline
允许您重现问题。这显然是一个浏览器错误,虽然元素未显示为内联或 block 元素,但对布局应该没有影响。
jsFiddles
Issue with Chrome and Safari on Macs only
Issue with extra CSS for IE7 only
注意!对我来说,使用 IE7 无法正确加载 Fiddle 页面,但结果 iFrame 的直接链接是 http://fiddle.jshell.net/z4dU7/3/show/
赏金更新!!!
我在下面发布了一个修复程序,但它实际上在 IE9 中引入了相同的布局问题!请随时改进或改进我的答案 - 或者带着完全不同的东西来到桌面! :)
最佳答案
<ul class="menu">
<li><span>Li</span></li>
<li><span>Li</span></li>
<li><span>Li</span></li>
<li class="change"><span>Li</span></li>
<li><span>Li</span></li>
</ul>
CSS
ul.menu {
overlflow: hidden;
}
ul.menu li {
float: left;
font-family: Verdana, Arial, Helvetica, sans-serif;
font-size: 10pt;
text-align:center;
margin: 0 0 0 -25px;
width: 152px;
line-height: 35px;
height: 35px;
background: url(../bct-white.png) no-repeat;
color: #0091c1;
}
ul.menu li span {
background: url(/green.png) no-repeat 5px 6px;
display: block;
}
ul.menu li.change span {
background-image: url(/red.png);
}
我提供的代码应用是Css2.0,在IE7及以上版本应该可以轻松运行。
img
标签和实现的美学(图像)作为背景span
必须添加,因为 CSS2 只允许每个元素有 1 个背景图像id="change"
至 class="change"
.除非您 100% 确定您将只有一个 #change 元素,否则请使用类。这纯粹是样式设计,它可以防止您在同一页面上有两个菜单列表。删除了顶部填充并增加了高度。所以你的 li 元素是相同的高度但是然后添加了 line-height: 35px
-> 这是垂直居中文本的最佳方式。使用顶部填充是可行的,但它很容易导致浏览器不一致。
更改 li
float 的元素。 float 元素是对 IE7 最友好的方法!即使 IE6 也不会出错,但我没有那个旧版本来测试你的网页。仅供引用 - ul.menu 必须有 overflow: hidden
清除 float 。
position: relative;
cursor: default;
除非您更改了默认值,否则您可以将这两个属性保留在外面。游标应该是默认的。 Position: relative 是不必要的 - 你没有使用绝对定位或任何需要它的东西。现在,您可以将这些保留在您的声明中。我只是希望代码尽可能“ slim ”。
最后的话:
看看我的 CSS。注意我是如何使用 ul.menu
的在我所有的声明中。您可能想养成这样做的习惯;这为开发人员提供了一些关于 HTML 外观的见解,更重要的是 - 如果您决定添加 <div class=menu>
,您的 css 将不会被覆盖。稍后的。具体.menu img
将应用于菜单 div 中的任何图像标签。
好的 - 就是这样。如果有任何说明,请告诉我。
仅供引用 - 看到这个问题有赏金,如果你向我提供背景图片,我可以完善我的代码以满足你的需求 100% - 也许在你的答案的编辑中上传它们。
关于css - 带 CSS 显示的元素 : none; breaking layout - causing misalignment,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17590886/
我有一个名为 main.css 的 css 文件和另一个名为 style.css 的文件。我怎样才能在 main.css 中做到这一点? .someClass { //apply rules to
在更新我的 css 之前,我在 Login.css 中有以下内容: body { background-image: url('./pictures/fond.png'); bac
我的 share point 2013 核心 css 和我的 css 之间存在 css 冲突。所以我想把我所有的类都放在 div #s4-workspace 下但是我搜索了一种方法来将所有类分组到这个
我知道您可以覆盖 jsp 页面从 jsp 包含 CSS 文件(即全局 CSS 文件)继承的 CSS 属性。 但是,如果元素中的某个属性弄乱了特定页面,而我不想只使用内联 CSS 在该页面中使用它怎么办
我刚刚发现了 initial-scale 元属性。 以前,我一直在使用 default.css 来定义我所有的样式和大小(用于字体和元素),以便它们在桌面计算机的屏幕上显示得很好。然后,如果您使用的是
我正在尝试使用 LESS CSS 来编写我的 CSS。我已经按顺序导入了 style.less 和 less.js 文件。 现在我想提取 LESS 生成的 CSS。有什么办法可以做到吗?我不想使用脚本
我想知道是否有任何一种软件可以读取大量内联样式中的 HTML 文档并将所有这些样式转换为外部 css 文件。如果只有一页,我可以手动完成。但是有100页。有人有想法吗? 最佳答案 就像有人说的那样,“
当我想从 Styled Components 迁移到 CSS Modules 时,出现了以下问题。 假设我有以下样式组件,它接受动态参数 offset和一个动态 CSS 字符串 theme : con
有没有办法将 CSS 类定义为与另一个类相等?例如,如果我有一个类: .myClass{ background-color: blue; } 有没有一种方法可以将第二个类定义为与 myClas
我正在尝试制作一组按钮,这些按钮贴在页面底部并且由固定的空间隔开。我正在使用 angularJS 的 ng-repeat 指令通过 ajax 请求获取数据,然后我用它来显示按钮。 我的问题在于让按
浏览器是否在加载 CSS 文件时解析 CSS?还是在整个 CSS 文件被浏览器下载后才进行解析?不同浏览器的做法有区别吗?我在哪里可以找到这种底层信息? 这个问题不是 Load and executi
这个问题在这里已经有了答案: Can a CSS class inherit one or more other classes? (29 个答案) 关闭 3 年前。 标题有点乱,我给大家看一下。假
我遇到了最奇怪的问题...... 在最简单的形式中,我有一个包含以下内容的 index.html 文件: (在尝试确定根本原因的过程中,我已经大大减少了它) 当我查看页面的源代码时,我得到以下信息:
我正在使用 Mindscape Workbench 来最小化我的 scss 文件。我的页面设置为使用 *.min.css 文件。在随机时间,min 文件不会与系统的其余部分一起发布。 我有很多 css
请告诉我 CSS 框架和 CSS 网格之间的区别。 最佳答案 CSS 框架也可以是 CSS 网格框架。 CSS 网格框架用于构建 CSS 布局。有一些框架除了构建布局还有其他用途,例如 Hartija
我有无法从页面中删除或更改的 original.css 文件。原始.css table { border-collapse: collapse; border-spacing: 0;
我以前使用 bootstrap css import 很好。 但是我正在尝试使用 CSS 模块,所以我添加了几行。 { test: /\.css$/, use:
有没有办法在 css 选择器中创建一个 css 组。 例如: .SectionHeader { include: .foo; include: .bar; include: .
今天我学习了 CSS 中的两个概念,一个是 CSS 定位(静态、相对、绝对、固定),另一个是 CSS Margin,它定义了元素之间的空间。 假设我想移动一个元素,这是最好的方法吗?因为这两个概念似乎
var paths = { css: './public/apps/user/**/*.css' } var dest = { css: './public/apps/user/css/' } /
我是一名优秀的程序员,十分优秀!