.布局前的认知
1.1 三种基本方案
多栏布局有三种基本的实现方案:固定宽度、流动、弹性。
固定宽度。布局的大小不会随用户调整浏览器窗口大小而变化,一般是 900 到 1100 像素宽(最常见的是 960 像素)。
流动。布局的大小会随用户调整浏览器窗口大小而变化。(结合 CSS 媒体查询,能够适应最大和最小的屏幕,业界称之为 响应式设计。)
弹性。在浏览器窗口变宽时,不仅布局变宽,而且所有内容元素的大小也会变化。(实现太过复杂,不多介绍。)
1.2 布局高度
多数情况下,布局中结构化元素(乃至任何元素)的高度是 不必或者不应该设定的。因为保持元素 height 属性的默认值 auto 不变,才能使元素根据自己包含内容的增加而在垂直方向上扩展。这样扩展的元素会把下方的元素向下推,而布局也能随内容数量的增减而垂直伸缩。
1.3 布局宽度
为了使浏览器窗口宽度合理变化,布局能作出适当的调整,我们 需要精细地控制 布局宽度。
2.三栏-固定宽度布局
上代码:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>三栏-固定宽度布局</title>
- <style>
- * {
- margin: 0;
- padding: 0;
- }
- #wrapper{
- width: 960px;
- margin: 0 auto;
- border:1px solid;
- }
- header{
- background: #f00;
- }
- nav{
- background: #dcd9c0;
- width: 150px;
- float:left;
- }
- article{
- background: #ffed53;
- width: 600px;
- float: left;
- }
- aside{
- background: #6a6b6c;
- width: 210px;
- float: left;
- }
- footer{
- clear:both;
- background: #6a6b6c;
- }
- </style>
- </head>
- <body>
- <div id="wrapper">
- <header>
- This is header.
- </header>
- <nav>
- This is nav<br>
- This is nav<br>
- This is nav<br>
- </nav>
- <article>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- </article>
- <aside>
- This is aside.
- </aside>
- <footer>
- This is footer.
- </footer>
- </div>
- </body>
- </html>
说明几点:
通过给整个外包装(#wrapper)设定宽度值(960px),并将其水平外边距设定为 auto,就能实现居中。随着向里面添加内容,相关的栏的高度会增加。
设置宽度并浮动中间三栏(nav、article 和 aside),让它们并排显示。使用属性:width 和 float。
三栏的总宽度加起来要等于外包装的宽度(150 + 600 + 210 = 960)。同样使用该方法就可以加任意多栏,只要它们的总宽度等于外包装的宽度即可。
页脚(footer)位于浮动元素后面,所以就会尽量往上移动。解决这个问题的方法就是使用 清除浮动(clear:both;或者使用clear:left;也可以,因为这里只有左浮动元素)。
3.为栏设定内边距和边框
在上面的布局中,只要一调整各栏中的内容,布局就可能超过容器宽度,而右边的栏就可能滑到左边的栏下方。例如为了让内容与栏边界空开距离,为栏添加水平外边距和内边距,或者为了增加爱栏间距,为栏添加外边距,导致布局宽度增大,进而浮动栏下滑;又或者在栏中添加大图片,或者没有空格的长字符串(如长URL),也会导致栏宽大超过布局宽度。
示例:
CSS Code复制内容到剪贴板- article{
- background: #ffed53;
- width: 600px;
- float: left;
- padding: 10px 20px; /* 添加这一行CSS规则 */
- }
我们把这种现象称为 浮动滑移,可以使用三种方法来预防发生:
从设定的元素宽度中减去添加的水平外边距、边框和内边距的宽度和。
在容器内部的元素上添加内边距或外边距。
使用 CSS3 的 box-sizing 属性切换盒子缩放方式。应该该属性后,给元素添加边框和内边距都不会增大盒子,相反会导致内容变窄。
下面来讨论这三种方法:
3.1 重设宽度以抵消内边距和边框
由于上面给 article 栏添加了左右 20px 的水平边距,故将该栏宽度从 600px 减至 560px,故修改后的 article 栏 css 样式规则如下:
CSS Code复制内容到剪贴板- article{
- background: #ffed53;
- width: 560px; /* 这里 */
- float: left;
- padding: 10px 20px; /* 别忘了这里 */
- }
虽然能实现,但每次只要调整内、外边距就要重设布局宽度,非常烦人,而且还可能导致页面错乱。
3.2 给容器内部的元素应用内边距和边框
把外边距和内边距应用到内容元素上确实有效,前提是这些元素没有明确地设定宽度,这样它们的内容才会随着内、外边距的增加而缩小。
根据盒模型定义,没有宽度的元素在水平方向上会适应其父元素,其内容会随着外边距、边框和内边距的增加而减少。
考虑到将来修改的时候,一栏中可能包含大量不同内容的元素,如果想重新调整内容与容器边界的距离,就必须每个元素都要进行调整,这样不仅麻烦,而且容易出错。况且,给栏添加边框同样会增大栏宽,不可能通过为其包含的内容元素逐个添加应用样式来做到。
所以说,与其为容器中的元素添加外边距,不如 在栏中再添加一个没有宽度的 div,让它包含所有内容元素,然后再给这个 div 应用边框和内边距。如此一来,只要为内部 div 设定一次样式,就可以把让所有内容元素与栏边界保持一致的距离。而且,将来再需要调整时也会很方便。任何新增内容元素的宽度都由这个内部 div 决定。
还是拿 article 栏来开刀:
XML/HTML Code复制内容到剪贴板- <article>
- <div class="inner"> <!-- 添加一个div -->
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- This is article.<br>
- </div>
- </article>
增改样式如下:
CSS Code复制内容到剪贴板- article{
- background: #ffed53;
- width: 600px;
- float: left;
- }
- article .inner{
- margin: 10px;
- border:2px solid red;
- padding: 20px;
- }
从结果可以看出,中间栏的宽度并未因此有多少变化,因为内容区减少的宽度抵消了应用到内部 div 上的外边距、边框和内边距的总宽度。于是,我们可以这样结论:如果布局中的栏是浮动的,而且都设定了宽度,你就不要去动它!要动,就把内容放在内部 div 里,动这个 div。
3.3 使用 box-sizing:border-box
这是最简单的一个方法。只要在三个浮动的栏的 CSS 规则中分别 加上 box-sizing:border-box 声明,再给栏添加内边距(和边框)就不会导致盒子的宽度变化。此时,既不用调整栏宽去抵消增加的内边距,也不用使用内部 div。添加内边距的结果就是内容收缩。
示例:
以下是简介清晰的没有内部 div 的标记:
XML/HTML Code复制内容到剪贴板- <div id="wrapper">
- <header>
- <!-- 标题 -->
- </header>
- <nav>
- <ul>
- <!-- 链接 -->
- </ul>
- </nav>
- <article>
- <!-- 文本 -->
- </article>
- <aside>
- <!-- 文本 -->
- </aside>
- <footer>
- <!-- 文本 -->
- </footer>
- </div>
相应的,CSS 规则如下:
- * {
- margin: 0;
- padding: 0;
- }
- #wrapper{
- width: 960px;
- margin: 0 auto;
- border:1px solid;
- }
- header{
- background: #f00;
- }
- nav{
- box-sizing:border-box; /* 这里! */
- background: #dcd9c0;
- width: 150px;
- float:left;
- padding: 10px 20px; /* 添加内边距 */
- }
- article{
- box-sizing:border-box; /* 这里! */
- background: #ffed53;
- width: 600px;
- float: left;
- padding: 10px 20px; /* 添加内边距 */
- }
- aside{
- box-sizing:border-box; /* 还有这里!! */
- background: #6a6b6c;
- width: 210px;
- float: left;
- padding: 10px 20px; /* 添加内边距 */
- }
- footer{
- clear:both; /* 清除浮动,防止页脚往上移动 */
- background: #6a6b6c;
- }
结果如下:
多么好用的一个属性啊!当然也就少不了 但是 —— IE6 和 IE7 不支持该属性。
废话少说,解决方案 如下:
使用一个专门解决这个问题的腻子脚本(polyfill),名叫 borderBoxModel.js.
可以使用 条件注释 把它添加到 HTML 标记之后、结束的 </body> 标签之前,以保证在加载 DOM 之后再执行该脚本:
- <body>
- <!-- HTML 标记 -->
- <!-- 只让 IE8 之前的 IE 加载它 -->
- <!-- [if It IE 8] -->
- <script src="helpers/borderBoxModel.js"></script>
- <![endif]-->
- </body>
CSS,固定宽度
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]