0

0

2016.3.14CSS 盒模型_第四天_html/css_WEB-ITnose

php中文网

php中文网

发布时间:2016-06-24 11:24:15

|

1236人浏览过

|

来源于php中文网

原创

首先对于之前的拖更表示抱歉,因公派,前往上海,所以耽误了几天,以后会尽量按时更新.

今天课程主要介绍盒模型的基本概念,同时告诉大家,盒模型具体元素的构成。在最后面会介绍一下定位。

今日课程预览

CSS 盒模型 概述

立即学习前端免费学习笔记(深入)”;

首先大家看到的是什么?

有月饼和月饼盒,对么?

所以,我们今天的课程就叫做“一个月饼盒引发的深思”。

大家首先看到的是什么?

是不是一个盒子,很像我们中秋节的时候包装月饼的月饼盒子,对么?

其中两个月饼盒子之间的距离就是咱们要介绍的–>margin(外边距).

而咱们每个月饼都要有最外层的包装盒,而这个包装盒的厚度,就是咱们的–> border(边框).

那咱们的月饼不可能都是直接挨在一起的,对吧,那每个月饼之间的间距,咱们就叫做–> padding(内边距).

那咱们介绍了月饼盒,咱们的月饼总应该有吧。

对的,咱们月饼的宽度就是 –> width.

高度就是 –> height.

而咱们的月饼就叫做 –> element(元素).

内边距、边框和外边距都是可选的,默认值是零。

但是,许多元素将由用户代理样式表设置外边距和内边距。

可以通过将元素的 margin 和 padding 设置为零来覆盖这些浏览器样式。

这可以分别进行,也可以使用通用选择器对所有元素进行设置:

* {  margin: 0;  padding: 0;}

在 CSS 中,width 和 height 指的是内容区域的宽度和高度。

增加内边距、边框和外边距不会影响内容区域的尺寸,但是会增加元素框的总尺寸。

假设框的每个边上有 10 个像素的外边距和 5 个像素的内边距。

如果希望这个元素框达到 100 个像素,就需要将内容的宽度设置为 70 像素,请看下图:

提示:内边距、边框和外边距可以应用于一个元素的所有边,也可以应用于单独的边。

提示:外边距可以是负值,而且在很多情况下都要使用负值的外边距。

代码和效果演示

在网页中,添加一个div标签,并设置class的值

HTML代码:<div class="box_model">    我是一个div哦</div>

设置自身大小

通常class选择器来设置属性值,首先是width(宽)、hegiht(高)、background-color(背景颜色)

CSS代码:.box_model { width: 200px; height: 200px; background-color: cyan;}

效果如下:

上述操作只是添加了一个div标签,并设置了文字、大小和颜色,并没有特殊操作。下面,我们继续:


设置padding 内边距

看上面的图,发现文字紧贴着边框,看着不是特别友好,如果想要添加一些边距,可以使用padding属性,来添加内边距

CSS代码:.box_model { width: 200px; height: 200px; background-color: cyan; /*内边距*/ padding: 20px;}

效果如下:

现在已经实现了文字和边框中间有了20像素的宽度,看着不是那么的紧凑了

注意:我们修改了padding的值,会导致div整体变大,因为padding属于div内部

如果我们希望div还是原来得大小,当我们设置了padding为20px,我们就需要修改width和height,分别减去40,才可以保证div大小不变

设置border 边框

看这样一个色块比较单调,来设置个有颜色的边框

凡科AI抠图
凡科AI抠图

简单好用的在线抠图工具

下载
CSS代码:.box_model { width: 200px; height: 200px; background-color: cyan; /*内边距*/ padding: 20px; /*边框*/ border: 50px solid black;}

效果图如下:

当设置了非常变态的50像素的边框之后,看到如下效果。通常,边框不会有那么大的值,1像素足够了

设置了边框的值,div标签的大小也会增加。边框也属于div本身

设置margin 外边距

外边距的主要作用就是设置该标签距离其它标签之间的距离

先来看下我们没有添加外边框代码时候div在浏览器中的样子

大家发现,在div标签的上部和左侧都有一段间距,这段间距是body的间距值(8px),先暂时忽略,不管它
然后我们添加外边距代码

CSS代码: .box_model { width: 200px; height: 200px; background-color: cyan; /*内边距*/ padding: 20px; /*边框*/ border: 50px solid black; /*外边距*/ margin: 50px;}

添加代码之后,效果如下:

现在,div标签距离浏览器的上部和左侧就有很大一段距离了,原因就是我们设置了外边框


注意事项

看下如下情况:

上面的div和下面的div标签,外边距都分别是50px,但是我们可以注意到,上面和下面之间的间距并不是100px,而同样也是50px,这是因为什么呢?

外边距在垂直距离上,并不会相加,而是取较大值。

举个例子: 如果上面的标签设置的外边距为100px,下面的标签这是外边距为80px,那么上下两个元素之间的距离九会为100px,取较大值。

这是两个元素竖直排列,那如果横排呢??

想多了,如果元素横排,那两个标签之间的间距就是两个元素的外边距之和


属性详写

内边距属性

  • padding
  • padding-left
  • padding-top
  • padding-right
  • padding-bottom
  • padding: 20px; 代表上下左右内边距均为20px
    padding: 10px 20px; 代表上下内边距为10px,左右内边距为20px。第一个数字代表上下,第二个代表左右内边距的值。注意中间是空格哦

    边框属性

  • border : 同时设置上下左右的边框相关

  • border-left : 设置左侧边框相关

  • border-left-width : 设置左侧边框厚度
  • border-left-color : 设置左侧边框的颜色
  • border-left-style : 设置左侧边框的样式

  • border-top : 设置上部边框相关

  • border-top-width : 设置上部边框厚度
  • border-top-color : 设置上部边框颜色
  • border-top-style : 设置上部边框样式

  • border-right : 设置右侧边框相关

  • border-right-width : 设置右侧边框厚度
  • border-right-color : 设置右侧边框颜色
  • border-right-style : 设置右侧边框样式

  • border-bottom : 设置下部边框相关

  • border-bottom-width : 设置下部边框厚度
  • border-bottom-color : 设置下部边框颜色
  • border-bottom-style : 设置下部边框样式
  • border: 1px solid red; 代表上下左右边框厚度为1px,样式为solid,颜色为red.
    border-left: 2px double red; 代表设置左侧边框厚度为2px,样式为double,颜色为red.

    外边距属性

  • margin : 可以同时设置上下左右外边距
  • margin-left : 设置左侧外边距
  • margin-top : 设置上部外边距
  • margin-right : 设置右侧外边距
  • margin-bottom : 设置下部外边距
  • margin: 20px; 代表上下左右外边距均为20px
    margin: 10px 20px; 代表上下外边距为10px,左右外边距为20px。第一个数字代表上下,第二个代表左右外边距的值。注意中间是空格哦

    display

    display 属性规定元素应该生成的框的类型。

    这个属性用于定义建立布局时元素生成的显示框类型。

    对于 HTML 等文档类型,如果使用 display 不谨慎会很危险,因为可能违反 HTML 中已经定义的显示层次结构。

    对于 XML,由于 XML 没有内置的这种层次结构,所有 display 是绝对必要的。

    在这里咱们只介绍四个属性。

    *none

    *inline : 行标签,占一小块区域

    *block : 块标签,独占一行,可以设置宽高

    *inline-block :块标签,但是具有一些行标签的属性

    注释:CSS2 中有值 compact 和 marker,不过由于缺乏广泛的支持,已经从 CSS2.1 中去除了。

    附录:

    值 描述
    none 此元素不会被显示。
    block 此元素将显示为块级元素,此元素前后会带有换行符。
    inline 默认。此元素会被显示为内联元素,元素前后没有换行符。
    inline-block 行内块元素。(CSS2.1 新增的值)
    list-item 此元素会作为列表显示。
    run-in 此元素会根据上下文作为块级元素或内联元素显示。
    compact CSS 中有值 compact,不过由于缺乏广泛支持,已经从 CSS2.1 中删除。
    marker CSS 中有值 marker,不过由于缺乏广泛支持,已经从 CSS2.1 中删除。
    table 此元素会作为块级表格来显示(类似 ),表格前后带有换行符。
    inline-table 此元素会作为内联表格来显示(类似 ),表格前后没有换行符。 )。 )。 )。 )。 )。)
    table-row-group 此元素会作为一个或多个行的分组来显示(类似
    table-header-group 此元素会作为一个或多个行的分组来显示(类似
    table-footer-group 此元素会作为一个或多个行的分组来显示(类似
    table-row 此元素会作为一个表格行显示(类似
    table-column-group 此元素会作为一个或多个列的分组来显示(类似
    table-column 此元素会作为一个单元格列显示(类似
    table-cell 此元素会作为一个表格单元格显示(类似
    table-caption 此元素会作为一个表格标题显示(类似
    inherit 规定应该从父元素继承 display 属性的值。

    相关文章

    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
    pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

    本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

    616

    2026.02.13

    微博网页版主页入口与登录指南_官方网页端快速访问方法
    微博网页版主页入口与登录指南_官方网页端快速访问方法

    本专题系统整理微博网页版官方入口及网页端登录方式,涵盖首页直达地址、账号登录流程与常见访问问题说明,帮助用户快速找到微博官网主页,实现便捷、安全的网页端登录与内容浏览体验。

    194

    2026.02.13

    Flutter跨平台开发与状态管理实战
    Flutter跨平台开发与状态管理实战

    本专题围绕Flutter框架展开,系统讲解跨平台UI构建原理与状态管理方案。内容涵盖Widget生命周期、路由管理、Provider与Bloc状态管理模式、网络请求封装及性能优化技巧。通过实战项目演示,帮助开发者构建流畅、可维护的跨平台移动应用。

    91

    2026.02.13

    TypeScript工程化开发与Vite构建优化实践
    TypeScript工程化开发与Vite构建优化实践

    本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

    20

    2026.02.13

    Redis高可用架构与分布式缓存实战
    Redis高可用架构与分布式缓存实战

    本专题围绕 Redis 在高并发系统中的应用展开,系统讲解主从复制、哨兵机制、Cluster 集群模式及数据分片原理。内容涵盖缓存穿透与雪崩解决方案、分布式锁实现、热点数据优化及持久化策略。通过真实业务场景演示,帮助开发者构建高可用、可扩展的分布式缓存系统。

    54

    2026.02.13

    c语言 数据类型
    c语言 数据类型

    本专题整合了c语言数据类型相关内容,阅读专题下面的文章了解更多详细内容。

    29

    2026.02.12

    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法
    雨课堂网页版登录入口与使用指南_官方在线教学平台访问方法

    本专题系统整理雨课堂网页版官方入口及在线登录方式,涵盖账号登录流程、官方直连入口及平台访问方法说明,帮助师生用户快速进入雨课堂在线教学平台,实现便捷、高效的课程学习与教学管理体验。

    15

    2026.02.12

    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法
    豆包AI网页版入口与智能创作指南_官方在线写作与图片生成使用方法

    本专题汇总豆包AI官方网页版入口及在线使用方式,涵盖智能写作工具、图片生成体验入口和官网登录方法,帮助用户快速直达豆包AI平台,高效完成文本创作与AI生图任务,实现便捷智能创作体验。

    598

    2026.02.12

    PostgreSQL性能优化与索引调优实战
    PostgreSQL性能优化与索引调优实战

    本专题面向后端开发与数据库工程师,深入讲解 PostgreSQL 查询优化原理与索引机制。内容包括执行计划分析、常见索引类型对比、慢查询优化策略、事务隔离级别以及高并发场景下的性能调优技巧。通过实战案例解析,帮助开发者提升数据库响应速度与系统稳定性。

    56

    2026.02.12

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Swoft2.x速学之http api篇课程
    Swoft2.x速学之http api篇课程

    共16课时 | 1万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号