CSS 基础 3

目录 🚀

导读 -- target

盒子模型

看透网页布局的本质

盒子模型组成

边框(border) 

border-style

​编辑border-color

border-width

边框写法

简写 

 分开写

表格细线边框 

边框会影响盒子实际大小

内边距

内容

内边距-padding

padding属性简写

padding对盒子的影响

padding的特殊情况

外边距

什么是外边距

简写

块级盒子水平居中

外边距合并

嵌套块级元素垂直外边距的塌陷

清除内外边距 


创作不易多多支持😶‍🌫️🥳


导读 -- target

  • 能够准确阐述盒子模型的四个组成部分
  • 能够利用边框复合写法给元素添加边框
  • 能够计算盒子实际大小
  • 能够利用盒子模型布局模块案例
  • 能够给盒子设置圆角边框
  • 能够给盒子添加阴影
  • 能够给文字添加阴影

盒子模型

看透网页布局的本质

 

每一个网页都是由很多个盒子组成

网页布局流程:

  1.  准备好相关的网页元素, 网页元素基本都是盒子box
  2. 利用css 设置好盒子的样式, 然后摆放到相应的位置
  3. 往盒子里面装内容

盒子模型组成

         所谓盒子模型, 就是把html页面中的布局元素看做是一个矩形的盒子, 也就是一个盛装内容的容器,  css 盒子模型本质上就是一个盒子 , 封装周围的HTML元素, 他包括: 边框, 外边距, 内边距, 和实际内容. 

  • border   边框
  • content  内容
  • padding  内边距
  • margin    外边距

下面我们来看一个图来总结一下:

例如现在有一个div盒子, 我现在想给他添加一个边框, 可以这么来:

    <style>body {width: 400px;height: 200px;border-style: dashed;/* border-widht 是我们的边框粗细 一般使用px作为单位*/border-width: 5px;}</style><div> 这是一个div标签</div>

 

这只是一个示例, 下面将详细介绍:

边框(border) 

         我们第一眼看见这个边框, 是不是可以想到, 这个边框肯定是可以设置颜色的, 看到这个线条我们肯定可以看到边框是否有粗细. 居然有实现, 那么肯定有虚线等等样式

        下面我们就来看看边框都有哪些属性:

border的属性
属性作用
border-width定义边框的粗细, 单位是px
border-style边框的样式
border-color边框的颜色

border-style

         需要注意的是, 这里的border-style 的默认值是none, 也就是说, 如果你不设置border-style属性为除了none之外的值的话, 那么就是默认无边框, 即使是设置了border-width和border-color也会不显示边框

说明:

  • 如果提供全部四个参数值,将按上-右-下-左的顺序作用于四个边框。
  • 如果只提供一个,将用于全部的四条边。
  • 如果提供两个,第一个用于上-下,第二个用于左-右。
  • 如果提供三个,第一个用于上,第二个用于左-右,第三个用于下。
  • 要使用该属性,必须先设定对象的height或width属性,或者设定position属性为absolute。
  • 如果border-width不大于0,本属性将失去作用。
  • 对应的脚本特性为borderStyle。请参阅我编写的其他书目。

border-color

 border-color属性可以设置边框的颜色, 语法如下:

border-color: color;

说明:

  •  如果提供全部四个参数, 将按照 上>右>下>左的顺序作用于四个边框
  • 如果只提供一个, 那么就默认作用于全部的四条边
  • 如果提供两个, 第一个将作用于 上和下, 第二个作用于 左和右.
  • 如果提供三个, 第一个用于提供上, 第二个作用于左右, 第三个用于下
  • 要使用该属性, 必须先设定对象的height和width属性, 或者设定position属性为absolute
  • 如果border-width 等于0, 或者是border-style设置为none. 本属性将会失去作用

border-width

说明:

  • 如果提供全部四个参数值,将按上-右-下-左的顺序作用于四个边框。
  • 如果只提供一个,将用于全部的四条边。
  • 如果提供两个,第一个用于上-下,第二个用于左-右。
  • 如果提供三个,第一个用于上,第二个用于左-右,第三个用于下。
  • 要使用该属性,必须先设定对象的height或width属性,或者设定position属性为absolute。
  • 如果border-style设置为none,本属性将失去作用。
  • 对应的脚本特性为borderWidth。请参阅我编写的其他书目。

 

边框写法

简写 

例如:

width和style和color之间是没有顺序的 

 

说明:

  • 如使用该复合属性定义其单个参数,则其他参数的默认值将无条件覆盖各自对应的单个属性设置。
  • 默认值为:medium none。border-color的默认值将采用文本颜色。
  • 要使用该属性,必须先设定对象的height或width属性,或者设定position属性为absolute。
  • 对应的脚本特性为border。请参阅我编写的其他书目。
  • 关于对象的尺寸与边框,内外补丁等样式表属性的关系,请参看图例以及height和width属性。

 分开写

top上边框
right右边框
bottom下边框
left左边框

表格细线边框 

有时候我们想要表格的线更细一点

例如:

  两个单元格之间的边框重合了, 这就会导致他们比其他没有重合的边框会更粗

如何解决这种问题? 

使用属性: border-collapse: collapse

边框会影响盒子实际大小

 

        我们看这张图, 很明显你会发现, 一个盒子的大小不只是content的内容, 他还包含内边距padding和外边距margin, 还有边框的宽度.

        所以我们在修改变边框的时候, 就会修改边盒子的实际大小, 因此我们在测量盒子大小的时候, 不量边框, 如果测量的时候包含了边框, 则需要width height减去边框的宽度.

内边距

内容

内容很好理解, 也就是我们上图中content的部分.

        如果我们设置了一个如下的案例, 我们就会发现, 这个内容距离这个背景的边缘部分太紧凑了, 觉得不美观, 那我们可不可以把他变得离开这个边缘部分更远一点呢??         

        比如说就像这样, 如下图一样: 

        该如何设置?? 这就要用到我们的内边距了

内边距-padding

        使用padding属性来设置内边距, 即边框和内容之间的距离.

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

例如这里有一个盒子, 其中包含一些内容, 代码如下:

    <div>你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世界!!!你好世好</div><style>div {width: 200px;height: 200px;background-color: pink;}</style>

使用padding属性来修改他的边距:

1.上边距

            padding-top: 20px;

2. 左边距

            padding-left: 20px;

        从浏览器的控制台看到左边距为20px 

右边距和下边距同样如此, 此处不一一列举 

padding属性简写

padding对盒子的影响

1. 内容和边框有了距离, 添加了内边距

2. padding会影响盒子实际大小

对于低一点我们来回顾一下, 盒子的组成

回顾一下盒子模型, 盒子是由这几个部分组成:

  • 外边距 margin
  • 边框 border
  • 内边距  padding 
  • 内容   content 

box盒子的大小由这四个部分一起决定.

        其中如果我们修改了padding, 那势必会影响到盒子的大小. 修改padding同时也会影响内容和边框的距离.

        但是有时候我们不想修改box的大小, 但是需要修改padding的大小该怎么办?? 

修改width属性和height属性即可.

padding的特殊情况

         如果盒子本身没有指定width和height属性, 则此时设置padding属性不会撑开盒子大小.

外边距

什么是外边距

        外边距, 也就是上图中的margin. 是边框外的一层, 也是盒子的最外一层. 

        我们经常发现, 盒子和盒子直接是有距离的:

        例如上图中紫色的部分, 就是盒子和盒子之间的距离. 

        那我们如何来控制这个距离呢?? 可以使用属性 margin

margin: 控制盒子外边距的大小

例如, 这里有两个盒子, 代码如下:

    <div>1</div><div>2</div><style>div {background-color: burlywood;width: 200px;height: 200px;}</style>

 

下面我想要这两个div盒子中间隔开, 并且让这两个数字在这个正方形中间显示:

    <div>1</div><div>2</div><style>div {background-color: burlywood;width: 200px;height: 200px;line-height: 200px;text-align: center;margin: 10px;}</style>

简写

        margin的简写和padding一摸一样.

块级盒子水平居中

        让块级元素水平居中需要满足两点:

盒子必须设置width属性

盒子左右的外边距必须设置为auto

例如, 现在有一个盒子, 但是他在页面的左侧, 代码如下:

    <div></div><style>div {background-color: burlywood;width: 200px;height: 200px;}</style>

        但是我想要他居中显示. 

    <div></div><style>div {background-color: burlywood;width: 200px;height: 200px;margin: 0 auto;}</style>

我们margin还可以这样写:

        div {background-color: burlywood;width: 200px;height: 200px;margin-left: auto;margin-right: auto;}

也可以:

    <style>div {background-color: burlywood;width: 200px;height: 200px;/* margin: 0 auto 0; *//* margin: 0 auto; *//* margin-left: auto; margin-right: auto*/margin: auto;}</style>

我们只要保证左右设置为auto就可以.

外边距合并

        使用margin定义款级元素的垂直外边距时, 可能会出现外边距的合并.

这个例子可以参考:

    <div>1</div><div>2</div><style>div {background-color: burlywood;width: 200px;height: 200px;line-height: 200px;text-align: center;margin: 10px;}</style>

        1和2之间那个白色的高度为10px, 但是我设置了两个盒子的外边距都为10px,那两个盒子之间的距离不应该是20px吗, 这就是盒子外边距的合并

嵌套块级元素垂直外边距的塌陷

        对于嵌套关系的块元素, 父元素有上边距的同时子元素也有上外边距, 此时父元素会塌陷较大的外边距值.

清除内外边距 

        举两个例子

        我们观察这个图片, 发现, 这个123并不是贴着这个页面的最顶部和最左侧, 而是有一定的距离

        还有一个例子是:

    <ul><li>123</li></ul>

 

        我们放大来看这张图 

         可以发现这个标签有16px的外边距和40px的内边距.

        图中的方框中都是多出来的边距, 而不是我们手动设置的, 其实这就说明了我们的一些业内元素, 很多都是自己就默认有内外边距的.

        网页元素很多都带有默认的内外边距, 而且不同的浏览器默认的也不一致, 所以我们在布局之前就徐璈清楚下网页元素的内外边距:

* {margin: 0; /*清除外边距*/padding: 0; /*清除内边距*/
}





本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/90875.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《PPT 自我介绍》:一本让你的职场表现更加出色的秘籍?

这里提供一个2000字左右的PPT自我介绍模板制作指南&#xff1a; 自我介绍是面试或工作中常见的情况&#xff0c;利用PPT可以给人留下更深刻的印象。但如何快速且专业地制作一个自我介绍PPT呢?这里给大家介绍几点技巧&#xff1a; 1. 选择一个简洁大方的PPT模板 首先要选择一…

STM32F4X UCOSIII任务信号量

STM32F4X UCOSIII任务信号量 任务信号量与内核信号量对比内核信号量任务信号量 UCOSIII任务信号量API任务信号量发送函数任务信号量接收函数 UCOSIII任务信号量例程 之前的章节中讲解过信号量这个机制&#xff0c;UCOSIII除了有内核信号量之外&#xff0c;还有任务信号量。在UC…

前端项目练习(练习-002-NodeJS项目初始化)

首先&#xff0c;创建一个web-002项目&#xff0c;内容和web-001一样。 下一步&#xff0c;规范一下项目结构&#xff0c;将html&#xff0c;js&#xff0c;css三个文件放到 src/view目录下面&#xff1a; 由于html引入css和js时&#xff0c;使用的是相对路径&#xff0c;所以…

详解C语言—文件操作

目录 1. 为什么使用文件 2. 什么是文件 3. 文件的使用 文件指针 文件的打开和关闭 三个标准的输入/输出流&#xff1a; 4. 文件的顺序读写 对字符操作&#xff1a; fputc&#xff1a; fgetc&#xff1a; 练习复制整个文件&#xff1a; 对字符串操作&#xff1a;…

WebGL雾化

目录 前言 如何实现雾化 线性雾化公式 雾化因子关系图 根据雾化因子计算片元颜色公式 示例程序&#xff08;Fog.js&#xff09; 代码详解​编辑 详解如何计算雾化因子&#xff08;clamp()&#xff09; 详解如何计算最终片元颜色&#xff08;根据雾化因子计算片元颜色…

搭建自己的搜索引擎之四

一、前言 搭建自己的搜索引擎之三 介绍了通过HTTP RESTful 对ES进行增删改查&#xff0c;这一般手工运维ES时使用&#xff0c;程序代码中最好还是使用Java API去操作ES会更容易维护&#xff0c;但ES API竟然贼多&#xff0c;本篇介绍一下 四种 API及其简单使用。 注&#xff…

第1篇 目标检测概述 —(2)目标检测算法介绍

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。目标检测算法是一种计算机视觉算法&#xff0c;用于在图像或视频中识别和定位特定的目标物体。常见的目标检测算法包括传统的基于特征的方法&#xff08;如Haar特征和HOG特征&#xff09;以及基于深度学习的方法&#xff0…

Docker(三)、Dockerfile探究

Dockerfile探究 一、镜像层概念1、通过执行命令显化docker的机制 二、Dockerfile基础命令1、FROM 基于基准镜像【即构建镜像的时候&#xff0c;依托原有镜像做拓展】2、LABEL & MAINTAINER -说明信息3、WORKDIR 设置工作目录4、ADD & COPY 复制文件5、ENV 设置环境常量…

crypto:Alice与Bob

题目 根据题目描述&#xff0c;将98554799767分解成两个素数 得到两个素数101999和966233。根据题目提示把它们拼接起来进行md5的32位小写哈希

提升您的Mac文件拖拽体验——Dropzone 4 for mac

大家都知道&#xff0c;在Mac上进行文件拖拽是一件非常方便的事情。然而&#xff0c;随着我们在工作和生活中越来越多地使用电脑&#xff0c;我们对于这个简单操作的需求也越来越高。为了让您的文件拖拽体验更加高效和便捷&#xff0c;今天我们向大家介绍一款强大的工具——Dro…

[plugin:vite:css] [sass] Undefined mixin.

前言&#xff1a; vite vue3 TypeScript环境 scss报错&#xff1a; [plugin:vite:css] [sass] Undefined mixin. 解决方案&#xff1a; 在vite.config.ts文件添加配置 css: {preprocessorOptions: {// 导入scss预编译程序scss: {additionalData: use "/resources/_ha…

8章:scrapy框架

文章目录 scrapy框架如何学习框架&#xff1f;什么是scarpy&#xff1f;scrapy的使用步骤1.先转到想创建工程的目录下&#xff1a;cd ...2.创建一个工程3.创建之后要转到工程目录下4.在spiders子目录中创建一个爬虫文件5.执行工程setting文件中的参数 scrapy数据解析scrapy持久…

计算机视觉与深度学习-循环神经网络与注意力机制-RNN(Recurrent Neural Network)、LSTM-【北邮鲁鹏】

目录 举例应用槽填充&#xff08;Slot Filling&#xff09;解决思路方案使用前馈神经网络输入1-of-N encoding(One-hot)&#xff08;独热编码&#xff09; 输出 问题 循环神经网络&#xff08;Recurrent Neural Network&#xff0c;RNN&#xff09;定义如何工作学习目标深度Elm…

uniapp ssr发行后一直Hydration completed but contains mismatches Cannot find module

最开始我用前端网页托管的地址访问一直是 Hydration completed but contains mismatches 解决方案 要从云函数的地址访问项目。 先绑定域名&#xff0c;否则用uniapp自带地址访问一直是下载文件 设置路径 最后效果 uniapp ssr 云函数访问 MODULE_NOT_FOUND:Cannot fin…

2023 年 Bitget Wallet 测评

对Bitget Wallet钱包的看法 Bitget Wallet在安全性、产品实力和使用体验方面可与Metamask媲美&#xff0c;甚至有所超越&#xff0c;唯一稍显不足的是知名度稍逊一筹。在众多钱包中&#xff0c;Bitget Wallet是拥有最全面的钱包之一&#xff0c;尤其适合那些希望一步到位&…

最小生成树 | 市政道路拓宽预算的优化 (Minimum Spanning Tree)

任务描述&#xff1a; 市政投资拓宽市区道路&#xff0c;本着执政为民&#xff0c;节省纳税人钱的目的&#xff0c;论证是否有必要对每一条路都施工拓宽&#xff1f; 这是一个连问带答的好问题。项目制学习可以上下半场&#xff0c;上半场头脑风暴节省投资的所有可行的思路&a…

web:[极客大挑战 2019]Upload

题目 页面显示为一个上传&#xff0c;猜测上传一句话木马文件 先查看源代码看一下有没有有用的信息&#xff0c;说明要先上传图片&#xff0c;先尝试上传含有一句话木马的图片 构造payload <?php eval($_POST[123]);?> 上传后页面显示为&#xff0c;不能包含<&…

“益路同行”栏目专访第11期——柳州市雨花敬老服务中心陈勇梅

中国善网在本届&#xff08;第十届&#xff09;慈展会上特别推出了《益路同行》采访栏目&#xff0c;《益路同行》栏目旨在寻觅公益之路上同行者的故事&#xff0c;挖掘公益更深层次的内涵&#xff0c;探索新时代公益发展道路。希望公益企业、人物、故事被更多人看到&#xff0…

2.物联网射频识别,RFID通信原理,RFID读写器与标签无线交互方式、数据反馈方式,RFID调制与解调、编码方式,不同RFID标签与读写器

一。RFID无线识别的原理 1.RFID系统无线通信基本原理 如下图所示&#xff0c;左边是读写器&#xff08;刷卡器&#xff09;&#xff0c;右边是标签&#xff08;卡&#xff09;&#xff0c;中间通过无线通信方式。 标签&#xff1a;&#xff08;卡&#xff09; 读写器&#xff…

实战项目:VB实现小鸟快跑小游戏

文章目录&#xff1a; 一&#xff1a;效果演示 二&#xff1a;实现思路 三&#xff1a;代码实现 form1 效果图 代码 form2 效果图 代码 一&#xff1a;效果演示 效果图◕‿◕✌✌✌ 代码下载 二&#xff1a;实现思路 窗口1 就是实现窗口的跳转和关闭窗口2 1.先添加背…