6

考虑以下示例:

<!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盒子大小的浏览器上,这是按我想要的方式呈现的:

正确渲染 http://img.skitch.com/20100522-c75mhdut2q32yc7u5r2tkft1n4.png

然而,在 IE 6/7 上,这呈现为:

IE 6/7 渲染 http://img.skitch.com/20100522-f5pkgnwwceaak3t8fqq2w16gfm.png

如何在 IE 6/7 中获得与在其他浏览器中相同的渲染效果,而不需要以像素为单位设置大小?

4

4 回答 4

2

解决方案是使用 CSS 和 JavaScript 来替换浏览器供应商合谋对样式造成痛苦的表单控件。选择只是带有 onmouseup 事件的下拉菜单。JS 驱动的文本编辑器(丰富而简单)可以替换在线文本区域。甚至有专门用于此目的的库。(

于 2010-05-22T02:03:22.807 回答
1

一个快速的解决方法可能是用 IE6/7 浏览器破解它,select { *width:102.5%; _width:102.5%; }但如果太宽,它可能不会与像素对齐。

于 2010-05-22T00:57:32.370 回答
1

这在 CSS 中是不可能的。我做了一些研究,发现之前在这里问过同样的问题。解决方案是使用此boxsizing.htc文件并将以下行添加到您的 HTML 头部:

<!--[if lt IE 8]><style>input, textarea { behavior: url("boxsizing.htc"); }</style><![endif]-->
于 2010-05-22T01:34:24.857 回答
0

也许这可以帮助您:对 Internet Explorer 6、7 和 8 的 CSS3 支持。从页面:

IE-CSS3 是一个脚本,它为即将到来的 CSS3 标准中可用的几种流行的新样式提供 Internet Explorer 支持。

于 2010-05-22T00:36:58.067 回答