考虑以下示例:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<style type="text/css">
div { width: 15em }
input, textarea, select { width: 100%;
-moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box }
</style>
</head>
<body>
<form>
<div>
<input value="Input">
</div>
<div>
<textarea>Text area</textarea>
</div>
<div>
<select>
<option>One</option>
<option>Two</option>
<option>Three</option>
</select>
</div>
</form>
</body>
</html>
在支持border-box
框大小调整的浏览器上,按我的意愿渲染:
Correct rendering http://img.skitch.com/20100522-c75mhdut2q32yc7u5r2tkft1n4.png
然而,在IE 6/7上,它呈现为:
IE 6/7 rendering http://img.skitch.com/20100522-f5pkgnwwceaak3t8fqq2w16gfm.png
如何在IE 6/7中获得与其他浏览器相同的渲染,而无需设置像素大小?
答案 0 :(得分:2)
解决方案是使用CSS和JavaScript来替换浏览器供应商共谋的表单控件,从而使样式变得痛苦。选择只是一个带有onmouseup事件的下拉菜单。 JS驱动的文本编辑器(丰富而简单)可以替代在线的文本区域。甚至还有用于此目的的库。 (Example)
答案 1 :(得分:1)
快速解决方法可能是IE6 / 7浏览器 - 用select { *width:102.5%; _width:102.5%; }
之类的东西进行破解,但如果太宽则可能不会与像素对齐。
答案 2 :(得分:1)
CSS无法实现。我做了一些研究,发现在here之前问了同样的问题。解决方案是使用此boxsizing.htc文件并将以下行添加到HTML头:
<!--[if lt IE 8]><style>input, textarea { behavior: url("boxsizing.htc"); }</style><![endif]-->
答案 3 :(得分:0)
也许这可以帮到你:CSS3 support for Internet Explorer 6, 7, and 8。从页面:
IE-CSS3是一个提供的脚本 Internet Explorer支持多种 可用的流行新款式 即将推出的CSS3标准。