CSS——margin的IE6兼容问题

本文详细解析了IE6浏览器中常见的CSS Bug,包括双倍margin bug和3px bug,并提供了有效的解决方案,如调整浮动方向和使用特定的hack技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        	*{
        		margin:0;
        		padding: 0;
        	}
			ul{
				border: 1px solid #000;
				height:100px;
				list-style: none;
			}
			ul li{
				float:left;
				width:120px;
				height:40px;
				margin-left: 40px;
				background-color:orange;
			}
        </style>
    </head>
    <body>
		<ul>
			<li></li>
			<li></li>
			<li></li>
			<li></li>
			<li></li>
			<li></li>
		</ul>
    </body>

以上代码在IE6中会出现双倍margin bug:
当出现两个以上连续浮动的元素,携带和浮动方向相同的margin时,队首的元素会双倍margin。
解决方案:

  1. 使浮动的方向和margin的方向相反(前端工程师特别喜欢这样做。)
float:left;
margin-right:40px;
  1. 使用hack(没必要):单独给队首的元素写一个一半的margin
<li class="no1"></li>
ul li.no1{
		_margin-left:20px;
}

IE6的3px bug

        *{
        	margin:0;
        	padding: 0;
        }
		div{
			width:400px;
			height:400px;
			background-color:orange;
		}
		div p{
			margin-left:20px;
			width:100px;
			height:100px;
			background-color:green;
		}

以上代码在IE6中margin-left会变成23px
解决方法:不用管,因为根本不允许用儿子踹父亲。如果你出现了3px bug,说明你的代码不标准。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值