当前位置: 首页 > news >正文

javaEE -13(6000字CSS入门级教程 - 2)

一:Chrome 调试工具 – 查看 CSS 属性

首先打开浏览器,接着有两种方式可以打开 Chrome 调试工具

  • 直接按 F12 键
  • 鼠标右键页面 => 检查元素

在这里插入图片描述
点开检查即可

标签页含义:

  • elements 查看标签结构
  • console 查看控制台
  • source 查看源码+断点调试
  • network 查看前后端交互过程
  • application 查看浏览器提供的一些扩展功能(本地存储等)
  • Performance, Memory, Security, Lighthouse 暂时不使用, 先不深究

1.1 elements 标签页使用

  • ctrl + 滚轮进行缩放, ctrl + 0 恢复原始大小.
  • 使用 左上角 箭头选中元素
  • 右侧可以查看当前元素的属性, 包括引入的类.
  • 右侧可以修改选中元素的 css 属性. 例如颜色, 可以点击颜色图标, 弹出颜色选择器, 修改颜色. 例如字体大小, 可以使用方向键来微调数值.
  • 此处的修改不会影响代码, 刷新就还原了~
  • 如果 CSS 样式写错了, 也会在这里有提示. (黄色感叹号)

在这里插入图片描述

二: 元素的显示模式

在 CSS 中, HTML 的标签的显示模式有很多,此处只重点介绍两个:

  1. 块级元素
  2. 行内元素

2.1 块级元素

常见的元素:

h1 - h6
p
div
ul
ol
li

特点:

  • 独占一行
  • 高度, 宽度, 内外边距, 行高都可以控制.
  • 宽度默认是父级元素宽度的 100% (和父元素一样宽)
  • 是一个容器(盒子), 里面可以放行内和块级元素.
<style>.demo1 .parent {width: 500px;height: 500px;background-color: green;}.demo1 .child {/* 不写 width, 默认和父元素一样宽 *//* 不写 height, 默认为 0 (看不到了) */height: 200px;background-color: red;}</style>
<div class="demo1"><div class="parent"><div class="child">child1</div><div class="child">child2</div></div>
</div>

在这里插入图片描述
注意:

  • 文字类的元素内不能使用块级元素
  • p 标签主要用于存放文字, 内部不能放块级元素, 尤其是 div
<body><p><div>蛤蛤</div></p>
</body>

2.2 行内元素/内联元素

常见的元素:

a
strong
b
em
i
del
s
ins
u
span
...

特点:

  • 不独占一行, 一行可以显示多个
  • 设置高度, 宽度, 行高无效
  • 左右外边距有效(上下无效). 内边距有效.
  • 默认宽度就是本身的内容
  • 行内元素只能容纳文本和其他行内元素, 不能放块级元素
<style>.demo2 span {width: 200px;height: 200px;background-color: red;}
</style>
<div class="demo2"><span>child1</span><span>child2</span><span>child3</span>
</div>

结果如下:
在这里插入图片描述
注意:

  • a 标签中不能再放 a 标签 (虽然 chrome 不报错, 但是最好不要这么做).
  • a 标签里可以放块级元素, 但是更建议先把 a 转换成块级元素.

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

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

2.3改变显示模式

使用 display 属性可以修改元素的显示模式.

可以把 div 等变成行内元素, 也可以把 a , span 等变成块级元素.

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

三: 盒模型

每一个 HTML 元素就相当于是一个矩形的 “盒子”,这个盒子由这几个部分构成

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

在这里插入图片描述

3.1 边框

基础属性:

  • 粗细: border-width
  • 样式: border-style, solid 实线边框 dashed 虚线边框 dotted 点线边框( 默认没边框.)
  • 颜色: border-color
<!DOCTYPE html>
<html>
<head><style>div {width: 500px;height: 250px;border-width: 10px;border-style: solid;border-color: green;
}</style>
</head>
<body><div>test</div>
</body>
</html>

在这里插入图片描述
边框属性支持简写, 没有顺序要求:

border: 1px solid red;

可以改四个方向的任意边框.

border-top/bottom/left/right

注意:边框会撑大盒子
在这里插入图片描述
可以看到, width, height 是 500*250, 而最终整个盒子大小是 520 * 270. 边框10个像素相当于扩大了大小.

通过 box-sizing 属性可以修改浏览器的行为, 使边框不再撑大盒子.

* {box-sizing: border-box;
}

box-sizing: border-box;表示盒模型中的宽度和高度包括了边框和内边距的计算

3.2 内边距

padding 设置内容和边框之间的距离,默认内容是顶着边框来放置的. 用 padding 来控制这个距离

可以给四个方向都加上边距

  • padding-top
  • padding-bottom
  • padding-left
  • padding-right
div {height: 200px;width: 300px;
}<div>test
</div>

在这里插入图片描述
加上 padding 之后:

div {height: 200px;width: 300px;padding-top: 5px;padding-left: 10px;
}

在这里插入图片描述
此时可以看到带有了一个绿色的内边距

注意:

  • 整个盒子的大小从原来的 300 * 200 => 310 * 205. 说明内边距也会影响到盒子大小(撑大盒子).
  • 使用 box-sizing: border-box 属性也可以使内边距不再撑大盒子. (和上面 border 类似)

复合写法:
我们可以把多个方向的 padding 合并到一起. [四种情况都要记住, 都很常见]:

padding: 5px; 表示四个方向都是 5px
padding: 5px 10px; 表示上下内边距 5px, 左右内边距为 10px
padding: 5px 10px 20px; 表示上边距 5px, 左右内边距为 10px, 下内边距为 20px
padding: 5px 10px 20px 30px; 表示 上5px, 右10px, 下20px, 左30px (顺时针)

控制台中选中元素, 查看右下角, 是很清楚的:
在这里插入图片描述

3.3 外边距

外边距控制盒子和盒子之间的距离,我们可以给四个方向都加上边距

  • margin-top
  • margin-bottom
  • margin-left
  • margin-right
<!DOCTYPE html>
<html>
<head><style>div {background-color: red;width: 200px;height: 200px;}
.first {margin-bottom: 20px;
}</style>
</head>
<body><div class="first">蛤蛤</div><div>呵呵</div>
</body>
</html>

在这里插入图片描述
复合写法:
规则同 padding

margin: 10px; // 四个方向都设置
margin: 10px 20px; // 上下为 10, 左右 20
margin: 10px 20px 30px; // 上 10, 左右 20, 下 30
margin: 10px 20px 30px 40px; // 上 10, 右 20, 下 30, 左 40

3.4 块级元素水平居中

前提:

  • 指定宽度(如果不指定宽度, 默认和父元素一致)
  • 把水平 margin 设为 auto

三种写法均可.

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

示例代码:

div {width: 500px;height: 200px;background-color: red;margin: 0 auto;
}<div>蛤蛤</div>

在这里插入图片描述
margin: 0 auto; 具体含义是将上下外边距设为0,左右外边距自动居中。

注意:

  • 这个水平居中的方式和 text-align 不一样.
  • margin: auto 是给块级元素用的.
  • text-align: center 是让行内元素或者行内块元素居中的.
  • 另外, 对于垂直居中, 不能使用 "上下 margin 为 auto " 的方式.

3.5 去除浏览器默认样式

浏览器会给元素加上一些默认的样式, 尤其是内外边距. 不同浏览器的默认样式存在差别,为了保证代码在不同的浏览器上都能按照统一的样式显示, 往往我们会去除浏览器默认样式,使用通配符选择器即可完成这件事情.

* {marign: 0;padding: 0;
}

四:弹性布局

4.1 flex 布局

flex 是 flexible box 的缩写. 意思为 “弹性盒子”.

任何一个 html 元素, 都可以指定为 display:flex 完成弹性布局.

flex 布局的本质是给父盒子添加 display:flex 属性, 来控制子盒子的位置和排列方式.

基础概念:

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

在这里插入图片描述
注意:

当父元素设置为 display: flex 之后, 子元素的 float, clear, vertical-align 都会失效.

4.2 常用属性

4.2.1 justify-content

设置主轴上的子元素排列方式.

属性取值
在这里插入图片描述

<!DOCTYPE html>
<html>
<head><style>div {width: 100%;height: 150px;background-color: red;display: flex;}div span {width: 100px;height: 100px;background-color: green;}</style>
</head>
<body><div><span>1</span><span>2</span><span>3</span><span>4</span><span>5</span></div>
</body>
</html>

未指定 justify-content 时, 默认按照从左到右的方向布局:
在这里插入图片描述
设置 justify-content: flex-end , 此时元素都排列到右侧了:
在这里插入图片描述
设置 jutify-content: center , 此时元素居中排列:
在这里插入图片描述
设置 justify-content: space-around,平分了剩余空间:
在这里插入图片描述
设置 justify-content: space-between,先两边元素贴近边缘, 再平分剩余空间.:
在这里插入图片描述

4.2.2 align-items

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

在上面的代码中, 我们是让元素按照主轴的方向排列, 同理我们也可以指定元素按照侧轴方向排列.

在这里插入图片描述

stretch(拉伸):意思是如果子元素没有被显式指定高度, 那么就会填充满父元素的高度.

<div>
<span>1</span>
<span>2</span>
<span>3</span>
</div>

在这里插入图片描述
我们可以使用 align-items 实现垂直居中:

<!DOCTYPE html>
<html>
<head><style>div {width: 500px;height: 500px;background-color: green;display: flex;justify-content: space-around;align-items: center;}div span {width: 150px;height: 100px;background-color: red;}</style>
</head>
<body><div><span>1</span><span>2</span><span>3</span></div>
</body>
</html>

在这里插入图片描述
注意:

align-items 只能针对单行元素来实现. 如果有多行元素, 就需要使用 item-content

相关文章:

javaEE -13(6000字CSS入门级教程 - 2)

一&#xff1a;Chrome 调试工具 – 查看 CSS 属性 首先打开浏览器&#xff0c;接着有两种方式可以打开 Chrome 调试工具 直接按 F12 键鼠标右键页面 > 检查元素 点开检查即可 标签页含义&#xff1a; elements 查看标签结构console 查看控制台source 查看源码断点调试ne…...

vscode 使用python无法导入库

刚刚在使用vscode,编辑python时&#xff0c;在使用语句 import matplotlib.pyplot as plt 时出现报错&#xff0c;但是在命令行下和conda环境中没有报错 在尝试 pip uninstall matplotlib pip install matplotlib后无法解决 之后再发现是工作的目录出错导致的&#xff0c;…...

三维向量旋转

三维向量旋转 问题描述问题分析 v ⃗ ∣ ∣ \vec{v}_{||} v ∣∣​的旋转 v ⃗ ⊥ \vec{v}_{\bot} v ⊥​的旋转 v ⃗ \vec{v} v 的旋转结论致谢 问题描述 如图1所示&#xff0c;设一个向量 v ⃗ \vec{v} v 绕另一个向量 u ⃗ [ x , y , z ] T \vec{u}[x,y,z]^{T} u [x,y,z]T…...

顺序表——leetcode

原地删除数据 我们的思路这里给的是双指针&#xff0c;给两个指针&#xff0c;从前往后移动&#xff0c;如果不是val就覆盖&#xff0c;如果是我就跳过&#xff0c;大家一定要看到我们的条件是原地修改&#xff0c;所以我们不能另开一个数组来实现我们这道题目。 这里我们给两…...

Kaprekar 7641 - 1467= 6174

package homework;import java.util.Arrays;import util.StringUtil;/*** 数学黑洞数6174&#xff0c;即卡普雷卡尔&#xff08;Kaprekar&#xff09;常数&#xff0c; 它的算法如下&#xff1a; 取任意一个4位数&#xff08;4个数字均为同一个数的除外&#xff09;&#xff0…...

李宏毅机器学习笔记.Flow-based Generative Model(补)

文章目录 引子生成问题回顾&#xff1a;GeneratorMath BackgroundJacobian MatrixDeterminant 行列式Change of Variable Theorem简单实例一维实例二维实例 网络G的限制基于Flow的网络构架G的训练Coupling LayerCoupling Layer反函数计算Coupling Layer Jacobian矩阵计算Coupli…...

Java使用Spark入门级非常详细的总结

目录 Java使用Spark入门 环境准备 安装JDK 安装Spark 编写Spark应用程序 创建SparkContext 读取文本文件 计算单词出现次数 运行Spark应用程序 总结 Java使用Spark入门 本文将介绍如何使用Java编写Spark应用程序。Spark是一个快速的、通用的集群计算系统&#xff0c;它可以处理…...

kubernetes集群编排——k8s存储

configmap 字面值创建 kubectl create configmap my-config --from-literalkey1config1 --from-literalkey2config2kubectl get cmkubectl describe cm my-config 通过文件创建 kubectl create configmap my-config-2 --from-file/etc/resolv.confkubectl describe cm my-confi…...

【软件STM32cubeIDE下H73xx配置串口uart1+中断接收/DMA收发+HAL库+简单数据解析-基础样例】

#【软件STM32cubeIDE下H73xx配置串口uart1中断接收/DMA收发HAL库简单数据解析-基础样例】 1、前言2、实验器件3-1、普通收发中断接收实验第一步&#xff1a;代码调试-基本配置&#xff08;1&#xff09;基本配置&#xff08;3&#xff09;时钟配置&#xff08;4&#xff09;保存…...

jdk8和jdk9中接口的新特性

jdk8之前&#xff1a;声明抽象方法&#xff0c;修饰为public abstract。 jdk8&#xff1a;添加声明静态方法&#xff0c;默认方法。 jdk9&#xff1a;添加声明私有方法 jdk8: ①接口中声明的静态方法只能被接口来调用&#xff0c;不能使用其实现类进行调用 静态方法的声明&…...

1-爬虫-requests模块快速使用,携带请求参数,url 编码和解码,携带请求头,发送post请求,携带cookie,响应对象, 高级用法

1 爬虫介绍 2 requests模块快速使用 3 携带请求参数 4 url 编码和解码 4 携带请求头 5 发送post请求 6 携带cookie 7 响应对象 8 高级用法 1 爬虫介绍 # 爬虫是什么&#xff1f;-网页蜘蛛&#xff0c;网络机器人&#xff0c;spider-在互联网中 通过 程序 自动的抓取数据 的过程…...

java商城免费搭建 VR全景商城 saas商城 b2b2c商城 o2o商城 积分商城 秒杀商城 拼团商城 分销商城 短视频商城

1. 涉及平台 平台管理、商家端&#xff08;PC端、手机端&#xff09;、买家平台&#xff08;H5/公众号、小程序、APP端&#xff08;IOS/Android&#xff09;、微服务平台&#xff08;业务服务&#xff09; 2. 核心架构 Spring Cloud、Spring Boot、Mybatis、Redis 3. 前端框架…...

【TS篇一】TypeScript介绍、使用场景、环境搭建、类和接口

文章目录 一、TypeScript 介绍1. TypeScript 是什么1.2 静态类型和动态类型1.3 Why TypeScript1.4 TypeScript 使用场景1.5 TypeScript 不仅仅用于开发 Angular 应用1.6 前置知识 二、如何学习 TypeScript2.1 相关链接 三、起步3.1 搭建 TypeScript 开发环境3.2 编辑器的选择3.…...

Tuna: Instruction Tuning using Feedback from Large Language Models

本文是LLM系列文章&#xff0c;针对《Tuna: Instruction Tuning using Feedback from Large Language Models》的翻译。 Tuna:使用来自大型语言模型的反馈的指令调优 摘要1 引言2 方法3 实验4 相关工作5 结论局限性 摘要 使用更强大的LLM&#xff08;如Instruction GPT和GPT-…...

uni-app 应对微信小程序最新隐私协议接口要求的处理方法

这里给大家分享我在网上总结出来的一些知识&#xff0c;希望对大家有所帮助 一&#xff0c;问题起因 最新在开发小程序的时候&#xff0c;调用微信小程序来获取用户信息的时候经常报错一个问题 fail api scope is not declared in the privacy agreement&#xff0c;api更具公告…...

PostgreSQL 进阶 - 使用foreign key,使用 subqueries 插入,inner joins,outer joins

1. 使用foreign key 创建 table CREATE TABLE orders( order_id SERIAL PRIMARY KEY, purchase_total NUMERIC, timestamp TIMESTAMPTZ, customer_id INT REFERENCES customers(customer_id) ON DELETE CASCADE);“order_id”&#xff1a;作为主键的自增序列&#xff0c;使用 …...

【Python 千题 —— 基础篇】地板除计算

题目描述 题目描述 编写一个程序&#xff0c;接受用户输入的两个数字&#xff0c;然后计算这两个数字的地板除&#xff08;整除&#xff09;结果&#xff0c;并输出结果。 输入描述 输入两个数字&#xff0c;用回车隔开两个数字。 输出描述 程序将计算这两个数字的地板除…...

【随手记】np.random.choice()函数

np.random.choice() 是 NumPy 中的一个随机抽样函数&#xff0c;用于从给定的一维数组中随机抽取指定数量或指定概率的元素。该函数可以用于构建模拟实验、生成随机数据集、数据抽样等应用场景。 np.random.choice(a, sizeNone, replaceTrue, pNone) 的参数如下&#xff1a; …...

2003-2022年地级市-财政收支明细数据(企业、个人所得税、科学、教育、医疗等)

2003-2022年地级市-财政收支明细数据&#xff08;企业、个人所得税、科学、教育、医疗等&#xff09; 1、时间&#xff1a;2003-2022年 2、指标&#xff1a;行政区划代码、年份、地区、一般公共预算收入、一般公共预算-税收收入、一般公共预算-税收收入-增值税收入、一般公共…...

影响服务器正常使用的有哪些因素

对于网站优化来说&#xff0c;网站服务器的优化绝对是基础。不管是用户还是搜索引擎对于网站的打开速度都是没有太多耐心的&#xff0c; 所以网站优化的就是要保证网站服务器稳定&#xff0c;网站正常且快速的打开 1.用户体验较差 现在越来越强调用户体验&#xff0c;设想一下…...

【云计算学习之路】学习Centos7系统-Linux网络配置管理

Linux网络TCP/IP协议概述OSI 七层模型与 TCP/IP 四层模型 协议对照表IP地址及网络常识IP地址A类IP地址B类IP地址C类IP地址D类IP地址特殊的网址子网掩码网关地址MAC地址Linux服务器IP命名规范Linux服务器网卡及主机名命名Linux服务器上网DNS设置Linux服务器默认网卡配置文件在/e…...

使用 curl 命令直接测试 Taotoken 聊天补全接口的步骤详解

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 使用 curl 命令直接测试 Taotoken 聊天补全接口的步骤详解 在开发或调试大模型应用时&#xff0c;有时我们希望在脱离特定编程语言…...

RH850 F1的FLASH自编程实战:如何在程序运行时安全更新数据闪存?

RH850 F1 FLASH自编程实战&#xff1a;如何在运行时安全更新数据闪存&#xff1f; 当车载ECU以120km/h行驶时&#xff0c;突然需要更新发动机标定参数——这个看似矛盾的场景&#xff0c;正是汽车电子工程师每天面对的挑战。RH850 F1系列微控制器独有的**后台操作(BGO)**功能&a…...

FPGA远程更新不止QUICKBOOT:深入MultiBoot机制,从Golden镜像设计到安全回滚的全链路解析

FPGA远程更新的安全架构设计&#xff1a;从MultiBoot机制到容错恢复的全链路实践 在工业自动化、通信基带和航空航天等关键领域&#xff0c;FPGA的远程更新能力直接关系到系统的可靠性与维护成本。传统QuickBoot方案虽然能实现基础的程序加载&#xff0c;但在面对复杂现场环境时…...

正点原子STM32MP135实战——OP-TEE安全启动与设备树深度适配

1. OP-TEE与STM32MP135开发板简介 第一次接触OP-TEE时&#xff0c;我也被这个专业名词唬住了。简单来说&#xff0c;它就像是你手机里的保险箱&#xff0c;专门用来存放和处理敏感信息&#xff08;比如指纹、支付密码&#xff09;。在STM32MP135这块开发板上实现OP-TEE&#xf…...

别再手动忽略.git和.svn了!WinMerge过滤器保姆级配置指南(附常用正则模板)

WinMerge高效过滤指南&#xff1a;彻底告别版本控制与构建文件干扰 接手新项目时&#xff0c;你是否曾被满屏的.git、.svn和.class文件对比结果淹没&#xff1f;WinMerge的过滤器功能正是解决这一痛点的利器。本文将带你从零开始配置专属过滤规则&#xff0c;让文件对比回归核心…...

UDP,TCP协议的格式与机制

目录 一&#xff1a;UDP 1.UDP协议端格式 2.UDP的特点 二&#xff1a;TCP 1.TCP协议段格式 2.确认应答机制 1.确认应答的原理 2.为什么有两个序号&#xff1f;——捎带应答 3.超时重传 4.快速重传 3.连接管理机制 1.三次握手 2.四次挥手 shutdown函数 COLSE_WAI…...

别再写if-else了!用Simulink的If-Action子系统建模,代码生成更清晰(附完整模型搭建步骤)

告别if-else嵌套噩梦&#xff1a;用Simulink If-Action子系统实现优雅的条件逻辑建模 在嵌入式系统开发中&#xff0c;复杂的条件分支逻辑就像房间里的大象——每个人都见过&#xff0c;却很少有人愿意正面处理。想象一下&#xff1a;当你面对一个深度嵌套的if-else结构&#x…...

求职路上的守护与成长

你有没有过这样的时刻——深夜对着海量的招聘信息发呆&#xff0c;投了无数简历却石沉大海&#xff0c;突然觉得前途一片迷茫&#xff0c;特别无助&#xff1f;记得有个学生&#xff0c;为了进心仪的央企准备了半年&#xff0c;却在二面屡屡受挫。那天老师陪他复盘到凌晨&#…...

Altium Designer 21 多通道设计保姆级教程:用Repeat语句快速搞定4路蜂鸣器模块

Altium Designer 21 多通道设计实战&#xff1a;4路蜂鸣器模块的高效实现 在复杂的电子系统设计中&#xff0c;我们常常会遇到需要重复使用相同功能模块的情况。传统的手动复制粘贴不仅效率低下&#xff0c;更会给后期维护带来巨大挑战。Altium Designer 21的多通道设计功能正…...