12 CSS中的盒子模型

技术交流QQ群:1027579432,欢迎你的加入!

欢迎关注我的微信公众号:CurryCoder的程序人生

  • 页面布局要学习三大核心,盒子模型、浮动和定位。学好盒子模型能非常好的帮助我们布局。
    网页布局.png

1.看透网页布局的本质

  • 网页布局过程
    • 先准备好相关的网页元素,网页元素基本都是盒子Box;
    • 利用CSS设置好盒子样式,然后摆放到相应的位置
    • 往盒子里面装内容;
  • 网页布局的核心本质:就是利用CSS摆放盒子!!!

2.盒子模型(Box Model)组成

  • 盒子模型:就是把HTML页面中的布局元素看成是一个矩形的盒子,也就是一个装着内容的容器。
  • CSS盒子模型的本质是一个盒子,封装周围的HTML元素,它包括:边框、外边距、内边距、实际的内容
    盒子模型组成1.png

    盒子模型组成2.png

3.边框border

边框.png
  • border可以设置元素的边框,边框有三部分组成:边框宽度(粗细)、边框样式、边框颜色
  • 语法格式:
    border: border-width || border-style || border-color
    
边框属性.png

4.边框的复合写法

  • CSS边框属性允许你指定一个元素边框的样式和颜色
  • 边框的复合写法:
    border: 1px solid red;  /* 三个参数是没有顺序的! */
    
  • 边框分开写法:
    border-top: 1px solid red;   /*  只设定上边框,其余方向同理  */
    

5.表格的细线边框

  • border-collapse属性控制浏览器绘制表格边框的方式它控制了相邻两个单元格之间的边框。
  • 语法格式:
    border-collapse: collapse;
    
  • collapse单词是合并的意思,border-collapse: collapse;表示相邻的边框合并在一起。

6.边框会影响盒子实际的大小

  • 边框会额外增加盒子的实际大小,因此有两种方法来解决:
    • 测量盒子大小的时候,不测量边框;
    • 如果测量的时候包含了边框,则需要width/height减去边框宽度

7.内边距padding

  • padding属性用于设置内边距,即边框与内容之间的距离。
    内边距属性.png

8.padding的复合写法

  • padding属性(简写属性)可以有1到4个值
    padding简写属性.png

9.padding会影响盒子的实际大小

  • 当我们给盒子设置padding值之后,发生了两件事情:
    • 内容和边距有了距离,添加了内边距;
    • padding会影响盒子实际的大小;
  • 注意:如果盒子已经有了宽度和高度,此时再指定内边距,就会撑大盒子。解决方法:如果保证了盒子与效果图大小保持一致,则让width/height减去多出来的内边距大小即可
  • 如果盒子本身没有指定width/height属性,则此时padding不会撑开盒子大小。

10.外边距margin

  • margin属性用于设置外边距,即控制盒子与盒子之间的距离。


    外边距的具体属性值.png
  • margin简写方式代表的意义与padding完全一致!

11.外边距的典型应用之块级盒子水平居中对齐

  • 外边距可以让块级盒子水平居中,但是必须满足两个条件:
    • 盒子必须指定了宽度width
    • 盒子左右的外边距都设置为auto
  • 语法格式:
    .header {
        width: 960px;
        margin: 0 auto;
    }
    
  • 常见写法用下面的三种:
    • margin-left: auto; margin-right: auto;
    • margin: auto;
    • margin: 0 auto;
  • 注意:上面的方法是让块元素水平居中对齐,如果想让行内元素或行内块元素水平居中,只需要给它的父元素添加text-align: center即可

12.外边距合并

  • 使用margin定义块元素的垂直外边距(即margin-top和margin-bottom)时,可能会出现外边距的合并。主要有下面的两种情况:
    • 相邻元素垂直外边距的合并
    • 嵌套元素垂直外边距的塌陷
1.相邻块元素垂直外边距的合并
  • 当上下相邻的两个块元素(兄弟关系的块元素)相遇时,如果上面的元素有下外边距margin-bottom,下面的元素有上外边距margin-top时,它们之间的垂直间距不是margin-bottom与margin-top之和。取两个值中的较大者这种现象被称为相邻块元素垂直外边距的合并
    相邻块元素垂直外边距的合并.png
  • 解决方法:尽量只给一个盒子添加margin值!
2.嵌套元素垂直外边距的塌陷
  • 对于两个嵌套关系(父子关系)的块元素,父元素有上外边距同时子元素也有上外边距,此时父元素会塌陷较大的外边距值
    嵌套元素垂直外边距的塌陷.png
  • 解决方法
    • 可以为父元素定义上边框;
    • 可以为父元素定义上内边距;
    • 可以为父元素添加overflow: hidden;

13.清除内外边距

  • 网页元素很多都带有默认的内外边距,而且不同的浏览器默认的值也不一致。因此,我们在布局前,首先要清除网页元素的内外边距。
  • 语法格式:
    * {
        padding: 0;  /* 清除内边距 */
        margin: 0;   /* 清除外边距 */
    }
    
  • 注意:行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。但是,将它转换为块级元素和行内块元素就可以设置上下内外边距了

14.PS的基本操作

  • 因为网页美工大部分效果图都是利用PS软件来做的,所以以后我们大部分切图工作都是在PS中完成。
  • 具体操作如下:
    • 1.文件→打开:打开我们要测量的图片;
    • 2.Ctrl+R:可以打开标尺,或者视图→标尺;
    • 3.右击标尺,把里面的单位改成像素;
    • 4.Ctrl+加号(+)可以放大视图,Ctrl+减号(-)可以缩小视图;
    • 5.按住空格键,鼠标箭头变成小手,拖到PS视图;
    • 6.用选区拖动,可以测量大小;
    • 7.Ctrl+D可以取消选区,或者在旁边空白处点击一下也可以取消选区;


      PS界面介绍.png

15.综合案例之产品模块

  • 网页布局分析如下:


    网页布局分析.png
  • 具体代码流程:
    • box布局
    * {
        margin: 0;
        padding: 0;
    }
    
    body {
        background-color: #f5f5f5;
    }
    
    .box {
        width: 298px;
        height: 415px;
        background-color: #ffffff;
        /* 让块级盒子水平居中对齐 */
        margin: 100px auto;
    }
    <div class="box"></div>
    
    • 图片和段落制作
    .box img {
    /* 图片的宽度和父亲一样宽 */
        width: 100%;
    }
    
    .review {
        height: 70px;
        font-size: 14px;
        /* 因为这个段落标签p没有width属性, 所以padding不会撑开盒子的宽度*/
        padding: 0 28px;
        margin-top: 30px;
    }
        
    <div class="box">
        <img src="images/img.jpg">
        <p class="review">快递牛,整体不错蓝牙可以说秒连,红米给力</p>
    </div>
    
    • 评价和详情制作
    .appraise {
        font-size: 12px;
        color: #b0b0b0;
        margin-top: 20px;
        padding: 0 28px;
    }
    
    .info {
        font-size: 14px;
        margin-top: 15px;
        padding: 0 28px;
    }
    
    .info h4 {
        display: inline-block;
        font-weight: 400;
    }
    
    .info span {
        color: #ff6700;
    }
    
    <div class="appraise">来自89757的评价</div>
    <div class="info">
        <h4>Redmi AirDots真无线蓝...</h4> |
        <span>99.9元</span>
    </div>
    
    • 竖线细节制作
    a {
        color: #333;
        text-decoration: none;
    }
    
    .info em {
        font-style: normal;
        color: #ebe4e0;
        margin: 0 6px 0 15px;
    }
    
    <div class="info">
        <h4>
            <a href="#">Redmi AirDots真无线蓝...</a>
        </h4>
        <em>|</em>
        <span>99.9元</span>
    </div>
    
  • 相关问题:
    • 1.布局为什么用不同的盒子,能否只用div
      • 答:标签都是有语义的,合理的地方用合理的标签。例如:产品的标题就用h标签,大量的文字就用p标签。
    • 2.为什么用那么多类名
      • 答:类名就是给盒子起了一个名字,可以更好的找到这个盒子,选取盒子更容易,后期维护也更方便。
    • 3.到底用padding还是margin
      • 答:大部分情况下两个可以混用,两者各有优缺点,但是根据实际情况,总是有更简单的方法实现。

16.综合案例之快报模板

  • 网页布局分析如下:


    网页布局分析.png
  • 具体代码流程:

    • 快报模块头部制作
    * {
        padding: 0;
        margin: 0;
    }
    
    .box {
        width: 248px;
        height: 163px;
        border: 1px solid #ccc;
        margin: 100px auto;
    }
    
    .box h3 {
        height: 32px;
        border: 1px dotted #ccc;
        font-size: 14px;
        font-weight: 400;
        line-height: 32px;
        /* 由于h3标签没有设定width属性,因此padding-left不会撑开盒子 */
        padding-left: 15px;
    }
    
    <div class="box">
        <h3>品优购快报</h3>
    </div>
    
  • 去掉li标签前的项目符号(小圆点)

    list-style: none;
    
    • 快报模块列表制作
    li {
    /* 去掉li前面的小圆点 */
        list-style: none;
    }
    
    .box ul li a {
        font-size: 12px;
        color: #666;
        text-decoration: none;
    }
    
    .box ul li a:hover {
        text-decoration: underline;
    }
    
    .box ul li {
        height: 23px;
        line-height: 23px;
        padding-left: 20px;
    }
    
    .box ul {
        margin-top: 7px;
    }
    
    <ul>
        <li>
            <a href="#">【特惠】爆款耳机5折秒!</a>
        </li>
        <li>
            <a href="#">【特惠】母亲节,健康好礼低至5折!</a>
        </li>
        <li>
            <a href="#">【特惠】爆款耳机5折秒!</a>
        </li>
        <li>
            <a href="#">【特惠】9.9元洗100张照片!</a>
        </li>
        <li>
            <a href="#">【特惠】长虹智能空调立省1000元</a>
        </li>
    </ul>
    

16.圆角边框[重点]

  • 在CSS3中,新增加了圆角边框样式,这样盒子模型就可以变成圆角了。
  • radius半径(圆的半径)原理:椭圆与边框的交集形成的圆角效果。
    圆角边框原理1.png

    圆角边框原理2.png
  • 语法格式:
    border-radius: 参数值;
    
  • 参数值可以是具体数值或百分比的形式;
  • 如果是正方形,想要设置为一个圆,把数值修改为高度或宽度的一半即可,或者直接写为50%;
  • 如果是矩形,设置为高度为一半就可以了
  • 该属性是一个简写属性,可以跟四个值,分别代表左上角、右上角、右下角、左下角
  • 分开写:border-top-left-radius、border-top-right-radius、border-bottom-right-radius、border-bottom-left-radius;

17.盒子阴影[重点]

  • 在CSS3中,新增加了盒子阴影,可以使用box-shadow属性为盒子增加阴影。
  • 语法格式:
    box-shadow: h-shadow v-shadow blur spread color inset;
    
盒子阴影属性值.png
  • 默认的是外阴影outset,但是不可以写这个单词,否则会导致阴影无效
  • 盒子阴影不占用空间,不会影响其他盒子排列

18.文字阴影

  • 在CSS3中,我们可以使用text-shadow属性将阴影应用于文本。
  • 语法格式:
    text-shadow: h-shadow v-shadow blur color;
    
文字阴影.png

19.资料下载

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352