CSS 的布局 盒子

news2024/11/15 9:34:40

目录

块级元素和行内元素

块级元素

特点:

行内元素

特点:

行内元素 和 块级元素 的区别

改变显示模式(把行内元素 变成 块级元素)

盒模型

盒模型图 

边框基础属性

内边框、外边框

基础写法:

复合写法

块级元素水平居中

前提:

去除浏览器默认样式

弹性布局

什么是 flex 弹性盒子?

基础概念:

常用属性

                justify-content       设置主轴上子元素的排列方式

                align-items             设置侧轴上的元素排列方式



 

块级元素和行内元素

块级元素

 h1 - h6     p    div    ul    ol    li 

特点:

  • 独占一行
  • 高度、宽度、内外边距、行高 都可以进行控制
  • 宽度默认和父级元素 一样宽
  • 是一个容器(盒子),里面可以放 行内元素 和 块级元素

行内元素

 strong   b   em   i   del      ins    u   span

特点:

  • 不独占一行,一行可以显示多个
  • 设置高度、宽度、行高无效
  • 左右外边距有效(上下无效) ,内边距有效
  • 默认宽度只能是本身内容
  • 行内元素只能容纳本文和其他行内元素,不能放块级元素

 

行内元素 和 块级元素 的区别

  • 块级元素独占一行,行内元素不独占一行
  • 块级元素可以设置宽 高,行内元素不能设置 宽高
  • 块级元素四个方向都能设置外边距,行内元素垂直方向不能设置

 

改变显示模式(把行内元素 变成 块级元素)

  • display:block  改成块级元素(常用)
  • display:inline  改成行内元素(很少用)
  • display:inline-block  改成行内块元素

  

盒模型

 

盒模型图 

每个 HTML元素 就相当于是一个矩形的 “盒子”

css的盒模型由里到外包括:content(内容)padding(内边距)border(边框)margin(外边距)

 

 

边框基础属性

  • 粗细:border-width
  • 样式:border-style (默认没有边框,solid实线 、dashed虚线、dotted点线边框)
  • 颜色:border-color
  • 让边框不会撑大盒子:box-sizing:border-box;

 

内边框、外边框

格式都一样 无非外边框替换成 margin,下面拿padding(内边框)举例子

基础写法:

padding-top 设置上面的边距

padding-bottom 设置下面边距

padding-left  设置左边边距

padding-right  设置右边边距

复合写法

padding:5px 10px 15px  20px(设置 上:5px    下:10px      左:15px       右:20px)

 

块级元素水平居中

前提:

  • 指定宽度
  • 把水平margin 设为 auto

例如:

<style>
        div {
            width: 500px;
            height: 200px;
            background-color: aqua;
            margin: auto;
        }
</style> 
<div>
    你好
</div>

去除浏览器默认样式

浏览器会给元素加上一些默认样式,尤其是内外边距,而不同的浏览器会有不同的默认样式,为了让我们的网页在任何地方显示的样式统一,我们往往会去除浏览器的默认样式

使用通配符:给所有元素加上格式

    <style>
        * {
            margin: 0;
            padding: 0;
        }
    </style>

弹性布局

初体验

1. 默认

    <style>
        div{
            width: 100%;
            height: 100%;
            background-color: blue;
        }
        div>span{
            background-color: green;
            width: 100px;
        }
    </style>
    <div>
        <span>1</span>
        <span>2</span>
        <span>3</span>
        <span>4</span>
    </div>

2. 当我们给div加上  display:flex

3. 再给 div 加上 justify-cotent:space-around;

 4. 把  justify-cotent:space-around; 改成 justify-content:flex-end;

 

什么是 flex 弹性盒子?

  •  flex 是 flexible box 的缩写,意思是“弹性盒子”
  • 任何一个 html 元素,都可以指定为display:flex 完成弹性布局
  • flex布局本质加上给父盒子添加 display:flex属性,来控制子盒子的 位置和排列方式

 

基础概念:

  • 被设置为 display:flex 属性的元素 ,称为 flex container
  • 他的所有子元素立刻成为了该容器的成员,称为flex item
  • flex item 可以纵向排列,也可以横向排列,称为 flex direction(主轴)

 

常用属性

justify-content       设置主轴上子元素的排列方式

  • justify-content:flex-start    项目位置容器开头,默认值
  • justify-content:flex-end    项目位于容器结尾
  • justify-content:center   项目位于容器中央
  • justify-content:space-between   项目在行与行之间留有间隔
  • justify-content:space-around   项目在 行之前、行之间、行之后 留有空间

align-items         设置侧轴上的元素排列方式

  • align-items: center;    朝着弹性容器的 中央 进行打包
  • align-items: flex-start;    朝着弹性容器的 开头 进行打包
  • align-items: flex-end;   朝着弹性容器的 结尾 进行打包
  • align-items: space-between;    行均匀分布在弹性容器中
  • align-items: space-around;   行均匀分布在弹性容器中,两端各占一半

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

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

相关文章

C++知识点大全(第二版)

目录 1 C简介 1.1 起源 1.2 应用范围 1.3 C和C 2开发工具 3 基本语法 3.1 注释 3.2关键字 3.3标识符 4 数据类型 4.1基本数据类型 4.2 数据类型在不同系统中所占空间大小 4.3 typedef声明 4.4 枚举类型 5 变量 5.1 变量的声明和定义 5.2 变量的作用域 6 运算…

如何当好硬软件助理工程师——实习周报(一)

如何当好硬软件助理工程师——实习周报 如何当好硬软件助理工程师——实习周报&#xff08;一&#xff09; 文章目录如何当好硬软件助理工程师——实习周报前言一、问题积累1.git 指令2.Coding的使用3.代码中的知识点&#xff08;HAL库、Flash读写&#xff09;a.gpio配置b.fla…

程序员必备的画图工具汇总

文章目录1、简介2、draw.io3、Excalidraw4、Xmind5、语雀6、Database6.1 dbdiagram.io6.2 sqldbm6.3 QuickDBD7、UML7.1 plantuml7.2 Graphviz结语1、简介 优秀的作图工具有许多&#xff0c;例如文本绘图工具 PlantUML&#xff0c;流程图设计工具 Draw.io&#xff0c;还有专业…

ORA-01861: literal does not match format string

系统&#xff1a;AnolisOS7.9 数据库&#xff1a;Oracle11.2.0.4 问题描述&#xff1a;执行TSPITR时&#xff0c;报错ORA-01861&#xff0c;如下所示&#xff1a; [oracleliujun~]$ export NLS_DATE_FORMATyyyy-mm-dd hh24:mi:ss [oracleliujun~]$ export NLS_LANGAMERICAN…

手写Mybatis源码(原来真的很简单!!!)

目录一、JDBC操作数据库_问题分析二、自定义持久层框架_思路分析三、自定义框架_编码1、加载配置文件2、创建两个配置类对象3、解析配置文件&#xff0c;填充配置类对象4、创建SqlSessionFactory工厂接口及DefaultSqlSessionFactory实现类5、创建SqlSession会话接口及DefaultSq…

R语言和医学统计学(10):正态性和方差齐性检验

本文首发于公众号&#xff1a;医学和生信笔记&#xff0c;完美观看体验请至公众号查看本文。 医学和生信笔记&#xff0c;专注R语言在临床医学中的使用&#xff0c;R语言数据分析和可视化。 文章目录前言正态性检验shapiro wilk检验kolmogorov smimov检验方差齐性检验两样本方差…

SSH框架重构需求,起码读懂代码和前端的原生JS

文章目录SSH(Spring Struts Hibernate)商城老项目JSPHtmlJsJquery 老项目部署Tomcat上面进行部署可以一次性部署多个项目1.Spring2.Struts3.Hibernate(持久层一个重量级框架)4.里面的请求路径解析SSH(Spring Struts Hibernate)商城老项目JSPHtmlJsJquery 老项目部署 Tomca…

【JavaSE之JDK8新特性】三万字详文带你了解JDK8新特性

JDK8新特性一、Lambda1.1需求分析2.Lambda表达式的初级体验3.Lambda表达式的语法规则3.1.Lambda练习13.2.Lambda表达式练习24.FunctionalInterfa注解说明5.Lambda表达式的原理6.Lambda表达式的省略写法7.lambda表达式的使用前提8.lambda和匿名内部类的对比二、接口中新增的方法…

#define宏的妙用!实现你以为的函数offsetof等

目录 一.#define 1.1#define的使用 1.2在define定义标识符的时候&#xff0c;要不要在最后加上 ;? 二.#define定义宏 2.1好代码的写法: 2.2#define 替换规则 2.3#和## 三.带有副作用的宏参数 四.宏和函数的对比 五.实现offetof 思路解析过程&#xff1a; 代码实现&am…

破解系统密码

一、利用5次shift漏洞破解win7密码 1.1 漏洞 1. 在未登录时&#xff0c;连续按5次shift键&#xff0c;弹出程序C:\Windows\System32\sethc.exe 2. 部分win7及win10系统在未进入系统时&#xff0c;可以通过系统修复漏洞篡改系统文件名&#xff01; 注意&#xff1a;如win7或win…

SpringBoot/Spring AOP默认动态代理方式

Spring 5.x中AOP默认依旧使用JDK动态代理SpringBoot 2.x开始&#xff0c;AOP为了解决使用JDK动态代理可能导致的类型转换异常&#xff0c;而使用CGLIB。在SpringBoot 2.x中&#xff0c;AOP如果需要替换使用JDK动态代理可以通过配置项spring.aop.proxy-target-classfalse来进行修…

【Linux】7.0 信号

文章目录信号的基本概念kill -l 查看信号列表信号的处理方式signal( ) 自定义处理信号信号的产生方式键盘产生进程异常&#xff08;core dump&#xff09;系统调用软件条件信号的发送&#xff08;OS&#xff09;信号常见相关名词解释进程接收处理信号原理信号集函数的使用打印p…

【Redis】3.详解分布式锁

文章目录1. 什么是分布式锁2. 分布式锁的特点3. 常见的分布式锁4. 实现分布式锁5.解决分布式锁中的原子性问题5.1 Lua脚本5.2 使用Java代码调用Lua脚本实现原子性1. 什么是分布式锁 分布式锁是指分布式系统或者不同系统之间共同访问共享资源的一种锁实现&#xff0c;其是互斥的…

【Django框架】——20 Django视图 02 路由命名和反向解析

文章目录一、 路由命名二、reverse反向解析三、通过URL模板页面进行传参四、namespace1.reverse反向解析2.url模板标签在 Django 项⽬中&#xff0c;⼀个常⻅需求是获取最终形式的 URL&#xff0c;⽐如⽤于嵌⼊⽣成的内容中&#xff08;视图和资源⽹址&#xff0c;给⽤户展示⽹…

《网络安全笔记》第七章:注册表基础

一、注册表基础 1、概述 注册表是windows操作系统、硬件设备以及客户应用程序得以正常运行和保存设置的核心“数据库”&#xff0c;也可以说是一个非常巨大的树桩分层结构的数据库系统注册表记录了用户安装在计算机上的软件和每个程序的相互关联信息&#xff0c;它包括了计算…

【UDS】ISO14229之0x2F服务

文章目录前言一、理论描述二、使用步骤1.请求2.响应总结->返回总目录<- 前言 简称&#xff1a; “InputOutputControlByIdentifier”&#xff0c;根据标识符控制输入输出 功能&#xff1a; 根据标识符控制输入输出服务用于替换输入信号的值、电控单元内部参数或控制电子…

Telnet连接

❤️人生没有白走的路&#xff0c;每一步都算数❤️ 你是否安装Telnet没毛病&#xff0c;但登录总报错&#xff1f; 巧了&#xff0c; 我也遇到了。 于是我打开浏览器尝试搜索&#xff0c;有许多说的并不详细。 所以呢就有了这篇文章&#xff01; 首先我们准备实验环境&#xf…

oracle中替换字符串的不同写法

replace函数 replace(原字段&#xff0c;“原字段旧内容“,“原字段新内容“) 例如将DEPTNO字段值中的0替换为1&#xff1a; TRANSLATE TRANSLATE(expr, from_string, to_string) from_string 与 to_string 以字符为单位&#xff0c;对应字符一一替换。 用法示例&#xf…

详解数据结构——二叉排序树

目录 二叉排序树 二叉排序树的查找 二叉排序树的插入 二叉排序树的删除 查找时间效率分析 二叉排序树 二叉排序树&#xff0c;又称二叉查找树&#xff08;BST&#xff0c;Binary Search Tree)一棵二叉树或者是空二叉树&#xff0c;或者是具有如下性质的二叉树: 左子树上所有结…

SpringBoot - SpringBoot整合i18n实现消息国际化

文章目录1. MessageSource源码2. 项目环境搭建1. 创建项目服务auth2. 工具类 I18nUtils3. 自定义异常 CommonException4. 统一异常处理 GlobalExceptionHandler3. 业务实现1. 实体类 UserEntity2. 请求实体 UserQo3. 控制层 UserController4. 业务逻辑层 UserService5. 将异常信…