- 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"
我创建了一个由按钮组成的水平菜单。我需要调整这些按钮的宽度,以便它们一起占据菜单容器宽度的 100%。它的行为方式应与 TD 在 TABLE 中的行为方式相同。
因此,这是我想出的代码:
<div id="menubar">
<div id="menu">
<div class="button">
<Button>Button 1</Button>
</div>
<div class="button">
<Button>Button 2</Button>
</div>
<div class="button">
<Button>Button 3</Button>
</div>
<div class="button">
<Button>Button 4</Button>
</div>
</div>
</div>
和我的 CSS:
#menubar {
width: 100%;
height: 100%;
display: table;
table-layout: fixed;
}
#menu {
display: table-row;
}
#menu .button {
position: relative;
display: table-cell;
}
#menu .button Button {
position: absolute;
right: 0px;
bottom: 0px;
top: 0px;
left: 0px;
}
这在除 Mozilla 之外的所有浏览器中都能完美运行。 Mozilla 似乎不尊重按钮类的相对位置,因此,所有按钮都绝对定位在彼此的顶部(而不是绝对在类“按钮”的 DIV 内)。
经过进一步研究,这似乎是 Mozilla 的一个已知问题,当显示设置为“表格单元格”时,这不是各自的“相对”位置。
有人知道实现我想要做的事情的变通方法吗?
注意:菜单是动态的,所以我不知道会有多少个按钮,所以我无法为每个按钮提供百分比宽度。
最佳答案
W3.org 的 CSS 规范指出 position: relative
的效果对于 table-cell 和其他表格元素是未定义的。
参见:http://www.w3.org/TR/CSS21/visuren.html#choose-position了解更多详情。
因此,某些浏览器似乎允许表格单元格的行为类似于表格单元格内任何绝对定位子元素的包含 block (有关更多详细信息,请参见 http://www.w3.org/TR/CSS21/visuren.html#comp-abspos)。但是,某些浏览器不会尝试扩展规范并且在应用于表格单元格时会忽略 position: relative
。
您看到的是兼容浏览器的正常行为,但对于 CSS 规范未定义的行为,浏览器可以自由地做或不做他们喜欢做的事,因此结果会有所不同。
我在这些情况下所做的是,我在具有绝对定位的单元格中放置一个 block 级包装元素(我设置偏移量以便包装填充表格单元格),然后绝对定位我的内部子元素相对于包装器。
以下 CSS 将允许按钮元素填充表格单元格的宽度和高度:
body, html {
height: 100%; /* if you want a to fil up the page height */
}
#menubar {
width: 100%;
height: 100%; /*or else fix this height... 100px for example */
display: table;
table-layout: fixed;
}
#menu {
display: table-row;
}
#menu .button {
display: table-cell;
border: 1px dotted blue;
height: 100%; /* scale the height with respect to the table */
}
#menu .button Button {
width: 100%;
height: 100%; /* scale the height with respect to the table cell */
}
您需要为 #menubar
设置高度,然后确保 table-cell 和按钮都具有 height: 100%
(想想一条链继承,表格到表格单元格,然后表格单元格到按钮)。
关于html - 相对位置不适用于显示表格单元格?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17526370/
我们有一个应用程序,我们可以在其中设计标签,然后根据设计创建图像并将其发送到打印机。图像在通过 TCP/IP 发送之前被制成字节流。 简而言之,我们有一个旋转设置,可以自动计算标签上不同元素的位置。而
我们在 IIS7 中有一个 MVC3 应用程序:http://mydomain.com/myapplication/ javascript 中的相对 URL 是什么: http://mydomain.
我的例子:http://jsfiddle.net/kwnk8qup/ 我的代码: container(父 div
如何将元素放置在右侧,并保持后面元素的持久位置? 我想在没有 Efficiently ... 的情况下将 text-align: right 对齐到右侧,并保留 t2 和 t3 元素之间的空间。 当我
假设我有一个包含以下文件的模块包。一个空文件 C:\codes\package\__init__.py 和一些重要文件: 一个位于C:\codes\package\first.py def f():
我正在尝试使用以下代码在屏幕上相对移动光标: input.type = INPUT_MOUSE; ZeroMemory(&input, sizeof(input)); input.mi.mouseDa
我排列了 3 个 div;中心 div 有许多 position:absolute 图像(它们重叠——一次显示一个图像;其余的是 display:none;对于 jQuery 交叉淡入淡出,这不是密切
我在 SQL 2000 数据库中有以下简化的表结构: ID AppName Key Value EffectiveDate -- ------- ----- ------- ---
给定以下配置: server { listen 80; server_name site.com; location /proxy { proxy_pa
我正在使用这些方法动态加载图像和资源目录,但它们并不适用于所有情况 new Uri(@"pack://application:,,/Images/lession_tab.png"); 此方法不适用于图
在插入/更新许多行时,我知道SQLite的“问题”,但事实并非如此。 我正在更新包含约250条记录的表中的ONE一行(由PK索引)中的ONE字段。查询通常需要200毫秒左右的时间。听起来很少,但很大。
如何向左或向右滑动线性布局。在该线性布局中,默认情况下我有一个不可见的删除按钮,还有一些其他小部件,它们都是可见状态,当向左滑动线性布局时,我需要使其可见的删除按钮,当向右滑动时,我需要隐藏该删除按钮
Imagen 我有一个 2D 点 (x,y) 列表,它们在我的简单游戏中描述了 2D 地形。 然后我让 glVertex() 在 GL_POINTS 模式下绘制所有这些点。 然后我有一个球,它也有它的
我正在使用 Google CloudSQL 并具有以下简单代码: ;dbname=', 'root', '' ); $db->setAttribute ( PDO::ATTR_ERRMODE, PDO
我知道有几个类似的问题,但是,其中的示例并没有说明问题,或者我无法从中获利 - 我真可耻。 所以我的问题是在带有 GUI 的简单应用程序中加载图像。例如: 我在 "D:\javaeclipseprog
我对放置在表格单元格内的 div 有疑问。单元格具有固定的高度和 div 相对于 height:100% 定位。 jsfiddle example td { height:80px;
我正在抓取一些数据。 我需要的数据点之一是日期,但包含此数据的表格单元格仅包括月份和日期。幸运的是,年份被用作对表格进行分类的标题元素。 出于某种原因,year = table.find_elemen
我想要一个 DIV,最大 90% 高度或 90% 宽度。我只想将图片作为背景放入 DIV 中,并且完整的 svg-image 应该是可见的。在移动设备和桌面设备上。 CSS: .camera {
我是网页设计新手,想了解 CSS 中定位的概念。我对相对和绝对定位元素有一些了解。在下面的 fiddle 中,我有一个 作为 的父级.当我做 p position:absolute ,边框崩溃不像我
我在调整图像高度相对于浏览器窗口的大小时遇到了一些严重的困难——宽度可以很好地调整大小,但高度保持不变。我尝试过 height: 100% 和 height: auto,以及 height: 10
我是一名优秀的程序员,十分优秀!