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里的内容会出现在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块的位置如图:
问题解决了,最后吐槽几句:解决这个问题的过程,是因为我用英文方式搜索到的国外网站上的结果,我也试过搜索“ul前的float元素”类似的,但都找不到想要的答案。对此我表示很无奈。
本文链接: http://www.jo2.org/204.html.转载请保留.
专职web前端,精通html,css,熟练javascript.努力学习新知识中
博客文章欢迎转载,但抵制剽窃。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .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语句:使用策略模式优化代码结构