- 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"
<ol>
<li>
<p>
Moo
<li>
<p class="overflow-hidden">
Moo
<li>
<p class="overflow-hidden">
Moo
<li>
<p>
Moo
</ol>
随附的 CSS:
p.overflow-hidden {
overflow-x: hidden;
}
你会期待类似的东西
但是在我的 Safari 和 Chrome 上……“2”。和“3”。被隐藏(但他们的“Moo”仍然存在):
为什么溢出会影响列表计数器/点?它在 <p>
上列表中的标签...啊,它伤害了我的大脑><
我是不是疯了,还是这是一个错误?
如果这不是错误..有人能解释一下吗?
我想象了“2”。属于li
而 overflow-x: hidden
适用于 child p
.因此即使是“2”。在p
之外...它与 overflow-x: hidden
没有关系因此应该不受影响 - 但事实并非如此..这是怎么回事?
最佳答案
你的理解是正确的;列表编号(在 CSS 中称为列表 标记)应该存在于 p
之外,不在里面。即使您指定 list-style-position: inside
也应该是这种情况因为就像你说的,你正在对 p
应用溢出, 而不是 li
.
一般来说,每个列表项都会为其子项创建一个主 block 框,并为标记所在的另一个框创建一个主 block 框。子元素都应该在主 block 框内呈现。来自CSS2.1 spec :
CSS 2.1 offers basic visual formatting of lists. An element with 'display: list-item' generates a principal block box for the element's content and, depending on the values of 'list-style-type' and 'list-style-image', possibly also a marker box as a visual indication that the element is a list item.
可以找到对主要 block 盒稍微更详细的解释here .
在你的例子中,每个 li
创建一个主 block 框和一个标记框。 p.overflow-hidden
元素应该驻留在主 block 框内并且不影响标记。这是一个粗略的 ASCII 艺术图来说明我的意思:
listmarker li principal block box+-----+ +----------------------------+| | |+--------------------------+|| • | || Moo (p block box) ||| | |+--------------------------+|+-----+ +----------------------------+
现在,规范似乎对标记框本身的定位含糊不清,但它确实说当 list-style-position
时标记框与主 block 框是分开的。是outside
.这似乎也意味着浏览器可以将标记框放置在主 block 框内,只要标记内容本身实际上位于该标记框内(顺便说一句,目前还不能用 CSS 作为目标)。
但 Safari 和 Chrome 似乎在做一些完全不同的事情:它们似乎不仅将标记框放在主框内,而且在主 block 框的第一个子框内。这就是为什么当它位于 p
之外时会被切断的原因 block 框:因为渲染引擎将其视为 p
的一部分content,看到它超出了它的水平边界,并将其切断。 (我怀疑它也被 overflow-y: hidden
剪掉了,因为它位于左边缘之外,这在 LTR 模式下通常不会发生,但这只是一个大胆的猜测。)
当您添加 list-style-position: inside
时到 li
, 其他浏览器正确移动 p
标记下方的 block 框,but Safari and Chrome simply move the marker into the p
box .尽管 CSS2.1 说它没有定义列表标记相对于列表项的主要 block 框的确切位置,但它确实说明了 list-style-position: inside
。 :
inside
The marker box is placed as the first inline box in the principal block box, before the element's content and before any :before pseudo-elements.
这显然不是 Safari 和 Chrome 对标记框所做的。
同样,规范(相当有意)不是 100% 清楚这一点,但我当然不希望列表标记是任何 li
的子项或受其影响。的子元素在 Safari 和 Chrome 中的显示方式。我很确定这是不正确的行为,即错误。
关于css - 带有嵌套 `overflow-x: hidden` 的列表隐藏了列表计数器/点 - 为什么/这是一个错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21769248/
我在leetcode上看到这段代码,是一道求众数的题,下面是题目描述: 给定一个大小为 n 的数组,找到多数元素。众数元素是出现次数超过 ⌊ n/2 ⌋ 次的元素。 你可以假设数组是非空的并且多数元素
每次在 JavaScript 中执行特定操作时,例如: $(function() { $('#typing').keyup(function () { switch($(this)
我一直在为网页设计一个计数器,但我一直被这个我无法解决的功能所困扰。 我有一个 4 个 div 的计数器,因为其中两个是小数字,另外两个是大数字,所以第一个运行得很快,我看不到它们的功能。 有人知道如
我已经在文档中进行了一些搜索,并在网上花了一段时间,但找不到解决方案!我希望警报告诉我单击 .thumb 时它处于each() 的哪一次迭代。 EG:有六个.thumb,我点击数字3,浏览器弹出3!
在 Handlebars 中,假设我有 names 的集合.我能怎么做 {{#each names}} {{position}} {{name}} {{/each}} 在哪里 {{position}}
这个问题在这里已经有了答案: Numbering rows within groups in a data frame (9 个回答) 4年前关闭。 我们如何在数据帧的每组中生成唯一的 ID 号?以下
我正在努力解决以下问题。我希望为给定的“一”序列创建一个计数器。例如,我有以下内容: 1 1 1 1 0 0 1 1 1 0 0 1 1 1 1 鉴于该序列,我希望为 1 的每个序列设置一个计数器直到
我正在努力解决以下问题。我希望为给定的“一”序列创建一个计数器。例如,我有以下内容: 1 1 1 1 0 0 1 1 1 0 0 1 1 1 1 鉴于该序列,我希望为 1 的每个序列设置一个计数器直到
我有一个jsfiddle here 这是一个简单的 JavaScript 函数,可以计算出设定的数字。 是否可以进行这种计数,但也保留一位小数 所以它算 1.1、1.2、1.3 等。 func
我正在构建一个计数器,当我按下鼠标时,它应该增加到 maxValue 并且减少不超过 0。我还可以选择将计数器重置为其初始值:0。另外,如果 maxValue 是偶数,它应该计数到该数字。但是,如果
所以我成功地为字母和单词构建了其他计数器,但现在我只能用这个来计算句子。我的代码如下,当我运行它时,它会返回很多错误消息: #include #include #include int main
Closed. This question is off-topic。它当前不接受答案。
我需要一个计数器,它会随着某些任务的完成而递增。我们只需要最后一小时的值,即窗口将移动而不是静态时间。 解决此问题的最佳方法是什么?我能想到的一种方法是拥有一个大小为 60 的数组,每分钟一个,并更新
我希望使用计数器来为我提供独特的引用系统。我想单击一个按钮,然后检查一个字段/文件中的最后一个数字,然后简单地向其添加 1,然后将其插入到屏幕上的字段中? 不确定执行此操作的最佳方法或具体如何执行此操
我有一个用 php 制作的表格,在该表格内我显示了数据库中的一些内容。我在每个 td 中创建了一个简单的按钮(类似于 Like),我希望每次点击它都会增加 1。这是带有按钮的行: echo "
如何将数据库中的值转换为可用于 if else 函数的 int 值? 例如:在我的数据库“armnumber = 3”中,如何在 if else 函数中使用它? 代码 string myConnect
我需要生成唯一的“ids”,问题是,它只能在 1 - 99999 之间。 “好”的是,它仅在与另一列组合时必须是唯一的。 我们有组,每个组都有自己的“group_id”,每个组都需要类似 unique
有这个简单的代码: UPDATE counter SET c= c +1 where id = 1; 并且它在开头的 c 字段中为 null 的情况下不起作用。它只有在已经输入了一些数字时才有效,也就
我正在尝试在 python 中构建一个具有闭包属性的计数器。以下工作中的代码: def generate_counter(): CNT = [0] def add_one():
我使用 CSS 来计算 HTML 文档中的部分: body {counter-reset: sect;} section:before { counter-increment: sect;
我是一名优秀的程序员,十分优秀!