zoukankan      html  css  js  c++  java
  • CSS——05-核心:盒子模型1

    人生苦短,要学就只学有用的

    【前端教学-CSS-5】

    CSS核心-盒子模型

    盒子模型(CSS重点)

    css学习三大重点: css 盒子模型 、 浮动 、 定位

    目标:

    • 理解:
      • 能说出盒子模型有那四部分组成
      • 能说出内边距的作用以及对盒子的影响
      • 能说出padding设置不同数值个数分别代表的意思
      • 能说出块级盒子居中对齐需要的2个条件
      • 能说出外边距合并的解决方法
    • 应用:
      • 能利用边框复合写法给元素添加边框
      • 能计算盒子的实际大小
      • 能利用盒子模型布局模块案例

    1.看透网页布局的本质

    网页布局中,我们是如何把里面的文字,图片,按照美工给我们的效果图排列的整齐有序呢?

    • 看透网页布局的本质:
      • 首先利用CSS设置好盒子的大小,然后摆放盒子的位置。
      • 最后把网页元素比如文字图片等等,放入盒子里面。
      • 以上两步 就是网页布局的本质

    我们明白了,盒子是网页布局的关键点,所以我们更应该弄明白 这个盒子有什么特点。

    2. 盒子模型(Box Model)

    • 所谓盒子模型:

      • 就是把HTML页面中的布局元素看作是一个矩形的盒子,也就是一个盛装内容的容器。

      总结:

      • 盒子模型有元素的内容、边框(border)、内边距(padding)、和外边距(margin)组成。
      • 盒子里面的文字和图片等元素是 内容区域
      • 盒子的厚度 我们成为 盒子的边框
      • 盒子内容与边框的距离是内边距(类似单元格的 cellpadding)
      • 盒子与盒子之间的距离是外边距(类似单元格的 cellspacing)

    标准盒子模型

    3. 盒子边框(border)

    • 语法:
    border : border-width || border-style || border-color 
    
    属性 作用
    border-width 定义边框粗细,单位是px
    border-style 边框的样式
    border-color 边框颜色
    • 边框的样式:
      • none:没有边框即忽略所有边框的宽度(默认值)
      • solid:边框为单实线(最为常用的)
      • dashed:边框为虚线
      • dotted:边框为点线

    3.1 边框综合设置

    border : border-width || border-style || border-color 
    

    例如:

     border: 1px solid red;  没有顺序  
    

    3.2 盒子边框写法总结表

    很多情况下,我们不需要指定4个边框,我们是可以单独给4个边框分别指定的。

    上边框 下边框 左边框 右边框
    border-top-style:样式; border-bottom-style:样式; border-left-style:样式; border-right-style:样式;
    border-top-宽度; border- bottom-宽度; border-left-宽度; border-right-宽度;
    border-top-color:颜色; border- bottom-color:颜色; border-left-color:颜色; border-right-color:颜色;
    border-top:宽度 样式 颜色; border-bottom:宽度 样式 颜色; border-left:宽度 样式 颜色; border-right:宽度 样式 颜色;

    3.3 表格的细线边框

    • 通过表格的cellspacing="0",将单元格与单元格之间的距离设置为0,

    • 但是两个单元格之间的边框会出现重叠,从而使边框变粗

    • 通过css属性:

      table{ border-collapse:collapse; }  
      
      • collapse 单词是合并的意思
      • border-collapse:collapse; 表示相邻边框合并在一起。
    <style>
    	table {
    		 500px;
    		height: 300px;
    		border: 1px solid red;
    	}
    	td {
    		border: 1px solid red;
    		text-align: center;
    	}
    	table, td {
    		border-collapse: collapse;  /*合并相邻边框*/
    	}
    </style>
    

    4. 内边距(padding)

    4.1 内边距:

    ​ padding属性用于设置内边距。 是指 边框与内容之间的距离。

    4.2 设置

    属性 作用
    padding-left 左内边距
    padding-right 右内边距
    padding-top 上内边距
    padding-bottom 下内边距

    当我们给盒子指定padding值之后, 发生了2件事情:

    1. 内容和边框 有了距离,添加了内边距。
    2. 盒子会变大了。(撑大了原来的盒子)

    注意: 后面跟几个数值表示的意思是不一样的。

    我们分开写有点麻烦,我们可以不可以简写呢?

    值的个数 表达意思
    1个值 padding:上下左右内边距;
    2个值 padding: 上下内边距 左右内边距 ;
    3个值 padding:上内边距 左右内边距 下内边距;
    4个值 padding: 上内边距 右内边距 下内边距 左内边距 ;

    练习:

    请写出如下内边距:

    1. 要求盒子有一个左边内边距是 5像素
    2. 要求简写的形式写出 一个盒子上下是 25像素 左右是15像素。
    3. 要求简写的形式写出 一个盒子 上内边距是 12像素 下内边距是 0 左内边距是 25像素 右内边距是 10像素

    4.3 练习: 新浪导航

    新浪导航栏的核心就是因为里面的字数不一样多,所以我们不方便给宽度,还是给padding ,撑开盒子的。注意:在日常的开发中,我们有时候需要利用这个特性,有时候也要消除这个特性带来的影响

    4.4 内盒尺寸计算(元素实际大小)

    • 宽度

      Element Height = content height + padding + border (Height为内容高度)

    • 高度

      Element Width = content width + padding + border (Width为内容宽度)

    • 盒子的实际的大小 = 内容的宽度和高度 + 内边距 + 边框

    4.5 内边距产生的问题

    • 问题

    会撑大原来的盒子

    • 解决:

      通过给设置了宽高的盒子,减去相应的内边距的值,维持盒子原有的大小

    课堂一练

    1. 一个盒子宽度为100, padding为 10, 边框为5像素,问这个盒子实际的宽度的是()
    • [x] (A) 130

    • [ ] (B) 135

    • [ ] (C) 125

    • [ ] (D) 115

      100 + 20 + 10

    1. 关于根据下列代码计算 盒子宽高下列说法正确的是()
    div {
    
    		 200px;
    
             height: 200px;
    
    		border: 1px solid #000000;
    
    		border-top: 5px solid blue;
    
    		padding: 50px;
    
    		padding-left: 100px;
    
    		}
    
    • [ ] (A) 宽度为200px 高度为200px
    • [x] (B) 宽度为352px 高度为306px
    • [ ] (C) 宽度为302px 高度为307px
    • [ ] (D) 宽度为302px 高度为252px

    算法:

        w  200 +   150   + 2   =  352
        h   200 +  100 +  6   =  306
    

    4.6 padding不影响盒子大小情况

    如果没有给一个盒子指定宽度, 此时,如果给这个盒子指定padding, 则不会撑开盒子。

    5. 外边距(margin)

    5.1 外边距

    ​ margin属性用于设置外边距。 margin就是控制盒子和盒子之间的距离

    5.2 设置:

    属性 作用
    margin-left 左外边距
    margin-right 右外边距
    margin-top 上外边距
    margin-bottom 下外边距

    margin值的简写 (复合写法)代表意思 跟 padding 完全相同。

    5.3 块级盒子水平居中

    • 可以让一个块级盒子实现水平居中必须:
      • 盒子必须指定了宽度(width)
      • 然后就给左右的外边距都设置为auto

    实际工作中常用这种方式进行网页布局,示例代码如下:

    .header{ 960px; margin:0 auto;}
    

    常见的写法,以下下三种都可以。

    • margin-left: auto; margin-right: auto;
    • margin: auto;
    • margin: 0 auto;

    5.4 文字居中和盒子居中区别

    1. 盒子内的文字水平居中是 text-align: center, 而且还可以让 行内元素和行内块居中对齐
    2. 块级盒子水平居中 左右margin 改为 auto
    text-align: center; /*  文字 行内元素 行内块元素水平居中 */
    margin: 10px auto;  /* 块级盒子水平居中  左右margin 改为 auto 就阔以了 上下margin都可以 */
    

    5.5 插入图片和背景图片区别

    1. 插入图片 我们用的最多 比如产品展示类 移动位置只能靠盒模型 padding margin
    2. 背景图片我们一般用于小图标背景 或者 超大背景图片 背景图片 只能通过 background-position
     img {  
    		 200px;/* 插入图片更改大小 width 和 height */
    		height: 210px;
    		margin-top: 30px;  /* 插入图片更改位置 可以用margin 或padding  盒模型 */
    		margin-left: 50px; /* 插入当图片也是一个盒子 */
    	}
    
     div {
    		 400px;
    		height: 400px;
    		border: 1px solid purple;
    		background: #fff url(images/sun.jpg) no-repeat;
    		background-position: 30px 50px; /* 背景图片更改位置 我用 background-position */
    	}
    
  • 相关阅读:
    drf 02 APIView的请求生命周期及各个模块源码分析和配置
    drf 03 序列化模块
    Django-restframework框架01
    javascript深入理解闭包(转)
    从经典问题来看 Copy 方法(转)
    JavaScript要点(七) 函数调用
    关于iOS中SQLITE句柄的使用的细节
    Xcode8 创建NSManageObject subclass方法
    JavaScript要点 (六) 函数参数
    JavaScript要点 (五) 函数定义
  • 原文地址:https://www.cnblogs.com/BM-laoli/p/12255317.html
Copyright © 2011-2022 走看看