CSS——margin的IE6兼容问题

        	*{
        		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,说明你的代码不标准。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值