UL,OL前有float元素导致定位bug

示例代码:

<p style="float:left; width:300px;margin-right:30px;">
<img src="xxx.jpg" alt="测试float与ol" />
</p>
 <ol>
      <li>首先打开动作面板点右边的下拉菜单,选择载入动作</li>
      <li>选择要载入的动作文件</li>
      <li>载入后我们就可以在动作面板下面找到刚才载入的动作。</li>
 </ol>

此时会看到下图中的效果:

错误的ol位置

ol里的内容会出现在p的右边,但整个OL块的位置其实是图中一样,left是顶着页面左边而非它前面的p元素的右边,此时p的margin对ol也会无效,所以可以看到,ol本身的序号都被挡住了。

这个时候给ol也加上float:left就可以正常了。但大部分时候这个float是本来不应该加的,而且会导致ol后面的元素定位错误。

这个问题看起来很无厘头,而且所有浏览器都这样,可以排除兼容性问题。

但解决这个问题也非常简单:给ol加上overflow,可以是auto或者hidden,但不能是visible(默认)。为了兼容IE,还得加上zoom:1.

完整CSS代码:

ul,ol{overflow:auto;zoom:1;}

此时在所有浏览器都正常了,ol块的位置如图:

正确的ol位置

问题解决了,最后吐槽几句:解决这个问题的过程,是因为我用英文方式搜索到的国外网站上的结果,我也试过搜索“ul前的float元素”类似的,但都找不到想要的答案。对此我表示很无奈。

 

本文链接: http://www.jo2.org/204.html.转载请保留.

posted on   十年灯  阅读(471)  评论(5编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
< 2011年9月 >
28 29 30 31 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 1
2 3 4 5 6 7 8

统计

点击右上角即可分享
微信分享提示