您的位置:首页 > Web前端 > HTML

使用乱序标签来控制HTML的输出效果

2005-05-18 13:23 671 查看
在HTML的元素中,有一个比较特殊的元素form。我们用它来收集表单数据并提交给服务器,并且理论上说来它是没有任何的UI被呈现的。当然如果我们在body元素后紧跟一个form,这样一来似乎看不出来有什么UI呈现的问题,可是当form存在于别的元素之中时,就有问题了。

什么问题呢?看下面的示例,由于页面布局的需要,我需要控制页面的滚动条。我把body的滚动条隐藏掉,然后使用一个div元素来"自制"一个滚动条,html代码如下:

<html>
<head>
<title>Layout Demo</title>
<meta name="author" content="birdshome@cnblogs.com">
</head>
<body style="border: 2px solid red; overflow: hidden; margin:0">
<div style="border: 2px solid yellow; width:100%; height: 100%; overflow: auto;">
<form>
<div style="width:800; height:800; border: 2px solid blue"></div>
</form>
</div>
</body>
</html>

挺好的一个自制的滚动条就出来了,可是如果这时把垂直滚动条拉到底,会发现一个页面布局缺陷,原来在form后IE会默认的加上一个<br>效果显示,如下图:
<form>
<div style="border: 2px solid yellow; width:100%; height: 100%; overflow: auto;">
<div style="width:800; height:800; border: 2px solid blue"></div>
</div>
</form>
这下显示完全乱套了,见下图:
<html>
<head>
<title>Layout Demo</title>
<meta name="author" content="birdshome@cnblogs.com">
</head>
<body style="border: 2px solid red; overflow: hidden; margin:0">
<div style="border: 2px solid yellow; width:100%; height: 100%; overflow: auto;">
<form>
<div style="width:800; height:800; border: 2px solid blue"></div>
</div>
</form>
</body>
</html>

注意div和form是相互嵌套的,这样的html就能得到我们说期望的UI了,如下图:



关于为什么要把body的滚动条hidden掉,然后自己用div来模拟?有空再来说了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐