CSS:如何设置表单控件的宽度,使它们都具有相同的宽度?

ave*_*net 6 css internet-explorer border-box

请考虑以下示例:

<!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>
Run Code Online (Sandbox Code Playgroud)

在支持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中获得与其他浏览器相同的渲染,而无需设置像素大小?

Bal*_*usC 1

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

<!--[if lt IE 8]><style>input, textarea { behavior: url("boxsizing.htc"); }</style><![endif]-->
Run Code Online (Sandbox Code Playgroud)