<div>
教程这节课和上一节课一样,需要大家在这个页面进行改动来体会 <div>
的用法。
我们已经学过「框模型」了。稍微复习一下,在脑子里过一遍「框」、「内边距」、「边框」、「外边距」分别都是什么东西,有什么对应的设置,看起来是什么样的。然后回忆一下 display
以及 box-sizing
属性的用法。再看看这个HTML 源文件顶端的 CSS,我在里面演示了个很方便的简便写法。如果你还想练习一下,可以给这一段加个 ID,然后随便设置点什么,再看看变化。
<div>
标签我觉得你已经非常熟练加边框、加边距那一套东西了。不过你仔细一想就会发现,局限性还是很大。你只能操作一个特定的元素。你可以给一个标题加上边框,你可以给一个段落加上边框,你却不能给一篇文章加上边框。譬如说下面这一篇。仅凭你目前所学,你不能搞一个大边框,然后把一整篇文章套住。
Nulla malesuada pellentesque elit eget gravida cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus mauris vitae ultricies leo integer malesuada nunc vel risus! Consectetur purus ut faucibus pulvinar elementum integer enim neque, volutpat ac tincidunt vitae, semper quis lectus nulla at volutpat diam ut venenatis tellus?
且慢。你要信仰 HTML 和 CSS 是万能的。如果有什么东西你觉得做不了,那么你一定大错特错,你只是还没学到那里而已。真相是否如此姑且不论,你要有这么个信仰才能写出好的网站。至少给文章加边框还是能做到的。
如果你想把一个「只能应用于一个元素」的操作应用在多个元素上面,那么很简单嘛,只要把那「多个元素」变成一个元素就可以了。HTML 有提供一个用得非常广泛的标签,叫 <div>
,专门用来做这个。div 是 division 的缩写,中文意思是分区。它的本质是把多个元素从结构上整合起来,或者说把多个部件抽象成一个整体,相当于人工造了一个新的「框」。用法也很简单,把它套在部件外面就可以了。
练习:把之前那篇文章套上一个 <div>
。用 CSS 给整篇文章加上一个边框。
其实你也可以再用一个 <p>
标签把上面那篇文章(<h4 id="stupid-border-h4>
和 <p id="stupid-border-p>
)括起来,然后给外面的 <p>
标签加边框。也就是说,把 <div>
直接换成 <p>
。但是不要那样子弄,不仅仅因为会导致 HTML 的语义不明确,还可能导致各种其他问题,比如你本来只打算用在段落上的 CSS 属性也作用于被包起来的标题上了。
<div>
的强大绝不止如此。既然他能够创造一个新的「框」,那么做个练习,把下面两篇文章并排起来,做个分栏效果。
Erat velit, scelerisque in dictum. Iaculis eu non diam phasellus vestibulum lorem sed risus ultricies tristique nulla aliquet enim tortor, at auctor urna nunc. Consequat id porta nibh venenatis cras sed felis eget velit aliquet sagittis id consectetur purus ut. Sit amet, porttitor eget dolor morbi. Ullamcorper eget nulla facilisi etiam dignissim diam quis enim lobortis scelerisque fermentum dui faucibus in ornare quam viverra orci! Nisl, condimentum id venenatis a, condimentum vitae sapien pellentesque habitant morbi tristique senectus et netus?
Odio facilisis mauris sit amet massa vitae tortor condimentum lacinia quis vel eros donec ac odio tempor orci dapibus ultrices in iaculis nunc sed augue lacus, viverra. Nulla malesuada pellentesque elit eget gravida cum sociis natoque penatibus et magnis dis! At elementum eu, facilisis sed odio morbi quis commodo odio aenean sed. A molestie lorem ipsum dolor sit amet, consectetur adipiscing elit ut aliquam, purus sit amet luctus venenatis, lectus magna fringilla urna, porttitor rhoncus dolor purus non enim praesent.
提示:box-sizing
。