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

CSS 值和单位详解:从基础到实战

CSS 值和单位详解:从基础到实战

    • 1. 什么是 CSS 的值?
      • 示例代码:使用颜色关键字和 RGB 函数
    • 2. 数字、长度和百分比
      • 2.1 长度单位
        • 绝对长度单位
        • 相对长度单位
      • 2.2 百分比
    • 3. 颜色
      • 3.1 颜色关键字
      • 3.2 十六进制 RGB 值
      • 3.3 RGB 和 RGBA 值
      • 3.4 HSL 和 HSLA 值
    • 4. 图像
      • 4.1 使用图像
      • 4.2 使用渐变
    • 5. 位置
    • 6. 字符串和标识符
    • 7. 函数
      • 7.1 使用 `calc()` 函数
    • 8. 总结
      • 完整示例代码

在 CSS 中,每个属性都允许使用一个或一组值。理解这些值和单位的使用方式,是掌握 CSS 的关键之一。本文将详细介绍 CSS 中常见的值和单位类型,并通过示例代码帮助你更好地理解它们的用法。

1. 什么是 CSS 的值?

在 CSS 规范和 MDN 的属性页面上,你会看到值通常被尖括号包围,例如 <color><length>。这些值表示你可以为该属性使用的有效数据类型。例如,<color> 表示你可以使用任何有效的颜色值,如颜色关键字、十六进制值、RGB 值等。

示例代码:使用颜色关键字和 RGB 函数

h1 {color: black;background-color: rgb(197, 93, 161);
}

在这个例子中,我们使用关键字 black 设置标题的颜色,并使用 rgb() 函数设置背景颜色。

2. 数字、长度和百分比

CSS 中有多种数值数据类型,包括整数、小数、带单位的数值和百分比。

2.1 长度单位

长度单位分为绝对长度单位相对长度单位

绝对长度单位

绝对长度单位是固定的,不随其他因素变化。常见的绝对长度单位包括:

  • cm:厘米
  • mm:毫米
  • in:英寸
  • px:像素
.box {width: 200px; /* 使用像素单位 */
}
相对长度单位

相对长度单位是相对于其他元素的尺寸。常见的相对长度单位包括:

  • em:相对于当前元素的字体大小
  • rem:相对于根元素的字体大小
  • vw:相对于视口宽度的百分比
  • vh:相对于视口高度的百分比
.box {width: 10vw; /* 视口宽度的 10% */font-size: 1.5em; /* 当前字体大小的 1.5 倍 */
}

2.2 百分比

百分比单位是相对于父元素的尺寸。例如,设置宽度为 50% 表示元素宽度为父元素宽度的一半。

.box {width: 50%; /* 父元素宽度的 50% */
}

3. 颜色

CSS 中有多种方式表示颜色,包括颜色关键字、十六进制值、RGB 和 HSL 值。

3.1 颜色关键字

CSS 提供了许多预定义的颜色关键字,如 redbluegreen 等。

.box {background-color: antiquewhite;
}

3.2 十六进制 RGB 值

十六进制颜色值由 # 开头,后跟六个十六进制数字,表示红、绿、蓝三个通道的值。

.box {background-color: #02798b;
}

3.3 RGB 和 RGBA 值

RGB 值使用 rgb() 函数表示,RGBA 值增加了透明度通道。

.box {background-color: rgb(2, 121, 139);background-color: rgba(2, 121, 139, 0.5); /* 50% 透明度 */
}

3.4 HSL 和 HSLA 值

HSL 值使用 hsl() 函数表示,HSLA 值增加了透明度通道。

.box {background-color: hsl(188, 97%, 28%);background-color: hsla(188, 97%, 28%, 0.5); /* 50% 透明度 */
}

4. 图像

CSS 中的 <image> 数据类型用于表示图像或渐变。

4.1 使用图像

.box {background-image: url('path/to/image.png');
}

4.2 使用渐变

.box {background-image: linear-gradient(90deg, rgb(119, 0, 255), rgb(0, 212, 255));
}

5. 位置

<position> 数据类型用于定位元素,如背景图像的位置。

.box {background-position: right 40px; /* 距离右侧 40px */
}

6. 字符串和标识符

CSS 中的字符串通常用于生成内容,而标识符是 CSS 能理解的特殊值,如颜色关键字。

.box::after {content: "这是个字符串。";
}

7. 函数

CSS 中的函数用于执行计算或生成值。常见的函数包括 calc()rgb()hsl() 等。

7.1 使用 calc() 函数

.box {width: calc(20% + 100px); /* 计算宽度 */
}

8. 总结

本文介绍了 CSS 中常见的值和单位类型,包括长度、百分比、颜色、图像、位置、字符串和函数。通过示例代码,你可以更好地理解这些值的用法。掌握这些基础知识后,你可以更灵活地使用 CSS 来设计和布局网页。

完整示例代码

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>CSS 值和单位示例</title><style>.box {padding: 10px;margin: 20px;border-radius: 0.5em;border: 2px solid #000;}.color-box {background-color: antiquewhite;}.gradient-box {background-image: linear-gradient(90deg, rgb(119, 0, 255), rgb(0, 212, 255));}.position-box {background-image: url('path/to/image.png');background-position: right 40px;}.calc-box {width: calc(20% + 100px);}</style>
</head>
<body><div class="box color-box">颜色关键字示例</div><div class="box gradient-box">渐变示例</div><div class="box position-box">背景位置示例</div><div class="box calc-box">calc() 函数示例</div>
</body>
</html>

通过本文的学习,你应该对 CSS 中的值和单位有了更深入的理解。继续实践和探索,你将能够更熟练地使用 CSS 来创建精美的网页设计。

相关文章:

CSS 值和单位详解:从基础到实战

CSS 值和单位详解&#xff1a;从基础到实战 1. 什么是 CSS 的值&#xff1f;示例代码&#xff1a;使用颜色关键字和 RGB 函数 2. 数字、长度和百分比2.1 长度单位绝对长度单位相对长度单位 2.2 百分比 3. 颜色3.1 颜色关键字3.2 十六进制 RGB 值3.3 RGB 和 RGBA 值3.4 HSL 和 H…...

【C++】P1957 口算练习题

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述输入格式&#xff1a;输出格式&#xff1a; &#x1f4af;我的做法代码实现&#xff1a; &#x1f4af;老师的做法代码实现&#xff1a; &#x1f4af;对比分析&am…...

Workbench 中的热源仿真

探索使用自定义工具对移动热源进行建模及其在不同行业中的应用。 了解热源动力学 对移动热源进行建模为各种工业过程和应用提供了有价值的见解。激光加热和材料加工使用许多激光束来加热、焊接或切割材料。尽管在某些情况下&#xff0c;热源 &#xff08;q&#xff09; 不是通…...

CCF-GESP 等级考试 2023年12月认证C++八级真题解析

2023年12月真题 一、单选题&#xff08;每题2分&#xff0c;共30分&#xff09; 正确答案&#xff1a;C 考察知识点&#xff1a;数学问题 解析&#xff1a;本题可抽象为分类计数问题&#xff0c;应使用加法原理&#xff0c;而不是乘法原理。答案为 ACB 的方案数 2 加上 ADB 的…...

Vant框架:助力移动端开发的利器

Vant框架&#xff1a;助力移动端开发的利器 在移动互联网飞速发展的今天&#xff0c;开发一款用户体验出色、界面美观且功能强大的移动端应用并非易事。而Vant框架&#xff0c;作为一款专为移动端设计的Vue.js UI组件库&#xff0c;凭借其轻量级、高度可定制化以及丰富的组件库…...

vscode搭建git

vscode搭建git 一、安装git二、vscode上搭建git(1) 先创建本地仓库再上传到远程仓库&#xff0c;远程仓库名是根据本地仓库名一致(2) 先创建远程仓库&#xff0c;再将本地仓库上传到指定远程仓库 一、安装git 网络教程很多&#xff0c;在此就不赘述了 参考&#xff1a;git安装…...

解决Mac安装软件的“已损坏,无法打开。 您应该将它移到废纸篓”问题

mac安装软件时&#xff0c;如果出现这个问题&#xff0c;其实很简单 首先打开终端&#xff0c;输入下面的命令 sudo xattr -r -d com.apple.quarantine 输入完成后&#xff0c;先不要回车&#xff0c;点击访达--应用程序--找到你无法打开的app图标&#xff0c;拖到终端窗口中…...

gltf工具

gltf 在线工具 ONLINE 3D VIEWER 3dviewer.netgltf-viewer cos.3dzhanting.cnviewer www.niushifu.topglTF Viewer gltf-viewer.donmccurdy.comGLTF 在线编辑器 gltf.nsdt.cloudgltfeditor...

ChatGPT-4o和ChatGPT-4o mini的差异点

在人工智能领域&#xff0c;OpenAI再次引领创新潮流&#xff0c;近日正式发布了其最新模型——ChatGPT-4o及其经济实惠的小型版本ChatGPT-4o Mini。这两款模型虽同属于ChatGPT系列&#xff0c;但在性能、应用场景及成本上展现出显著的差异。本文将通过图文并茂的方式&#xff0…...

在K8S中,如何把某个worker节点设置为不可调度?

在Kubernetes中&#xff0c;如果你想要把一个worker节点设置为不可调度&#xff0c;意味着你不想让Kubernetes调度器在这个节点上调度新的Pod。这通常用于维护或升级节点&#xff0c;或者当节点遇到硬件故障或性能问题时&#xff0c;要将某个worker节点设置为不可调度。 方法1…...

解决 LeetCode 922 题:按奇偶排序数组 II

解决 LeetCode 922 题&#xff1a;按奇偶排序数组 II 题目描述 给定一个非负整数数组 nums&#xff0c;其中一半整数是奇数&#xff0c;一半整数是偶数。要求对数组进行排序&#xff0c;以便当 nums[i] 为奇数时&#xff0c;i 也是奇数&#xff1b;当 nums[i] 为偶数时&#…...

读书笔记--分布式架构的异步化和缓存技术原理及应用场景

本篇是在上一篇的基础上&#xff0c;主要对分布式应用架构下的异步化机制和缓存技术进行学习&#xff0c;主要记录和思考如下&#xff0c;供大家学习参考。大家知道原来传统的单一WAR应用中&#xff0c;由于所有数据都在同一个数据库中&#xff0c;因此事务问题一般借助数据库事…...

BUU10 [极客大挑战 2019]LoveSQL1

万能用户名&#xff08;密码随便&#xff09; 登录进去以后发现是这个东西&#xff0c;然而并没有什么卵用 然后就开始爆破数据库名字--表名--列名 注意&#xff1a;这道题需要将所有的表名都爆出来&#xff0c;需要在payload里头写 group_concat()&#xff0c;否则页面只会显…...

tomcat核心组件及原理概述

目录 1. tomcat概述 1.1 概念 1.2 官网地址 2. 基本使用 2.1下载 3. 整体架构 3.1 核心组件 3.2 从web.xml配置和模块对应角度 3.3 如何处理请求 4. 配置JVM参数 5. 附录 1. tomcat概述 1.1 概念 什么是tomcat Tomcat是一个开源、免费、轻量级的Web服务器。 Tomca…...

【实战篇】Android安卓本地离线实现视频检测人脸

实战篇Android安卓本地离线实现视频检测人脸 引言项目概述核心代码类介绍人脸检测流程项目地址总结 引言 在当今数字化时代&#xff0c;人脸识别技术已经广泛应用于各个领域&#xff0c;如安防监控、门禁系统、移动支付等。本文将以第三视角详细讲解如何基于bifan-wei-Face/De…...

冰蝎v4.0.5 来啦

webshell始终是渗透测试的热门&#xff0c;上次护网写冰蝎检测规则&#xff0c;加密流量&#xff0c;有点压力&#xff0c;今天终于有空来复现一下&#xff0c;我知道玩知乎的大佬很多&#xff0c;轻一点喷&#xff0c;学习新知识不丢人&#xff5e; ailx10 1949 次咨询 4.9 …...

【C++】B2120 单词的长度

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目描述&#x1f4af;我的做法代码实现&#xff1a;思路解析&#xff1a; &#x1f4af;老师的第一种做法代码实现&#xff1a;思路解析&#xff1a; &#x1f4af;老师的…...

使用线性回归模型逼近目标模型 | PyTorch 深度学习实战

前一篇文章&#xff0c;计算图 Compute Graph 和自动求导 Autograd | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 使用线性回归模型逼近目标模型 什么是回归什么是线性回归使用 PyTorch 实现线性回归模型代码执行结…...

鱼香ros——编写第一个c++节点

ROS2中的节点了解 在 ROS 2&#xff08;Robot Operating System 2&#xff09;中&#xff0c;节点&#xff08;Node&#xff09; 是一个独立运行的进程&#xff0c;它可以执行特定的功能&#xff0c;如接收传感器数据、控制机器人执行任务或进行数据处理。 ROS 2 是一个分布式…...

深入浅出:频谱掩码 Spectral Masking —— 噪音消除利器

在语音处理领域&#xff0c;噪声是一个常见的敌人。无论是语音通话、语音识别&#xff0c;还是语音合成&#xff0c;噪声都会大大降低语音的质量和可理解性。为了解决这个问题&#xff0c;Spectral Masking&#xff08;频谱掩码&#xff09; 模型应运而生。它通过从带噪信号的频…...

C++ Primer 多维数组

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…...

Mac M1 ComfyUI 中 AnyText插件安装问题汇总?

Q1&#xff1a;NameError: name ‘PreTrainedTokenizer’ is not defined ? 该项目最近更新日期为2024年12月&#xff0c;该时间段的transformers 版本由PyPI 上的 transformers 页面 可知为4.47.1. A1: transformers 版本不满足要求&#xff0c;必须降级transformors &#…...

使用Java操作Redis数据类型的详解指南

SEO Meta Description: 详细介绍如何使用Java操作Redis的各种数据类型&#xff0c;包括字符串、哈希、列表、集合和有序集合&#xff0c;提供代码示例和最佳实践。 介绍 Redis是一种开源的内存数据结构存储&#xff0c;用作数据库、缓存和消息代理。它支持多种数据结构&#…...

数据结构(AVL树、B-Tree、B+Tree)

AVL树 AVL树是一种自平衡的二叉搜索树&#xff0c;它的特点是每个节点的左子树和右子树的高度差&#xff08;平衡因子&#xff09;的绝对值不超过1。这种平衡性保证了AVL树在进行查找、插入和删除操作时都能保持较高的效率。 平衡因子 在AVL树中&#xff0c;每个节点都维护一…...

可靠度的HLRF算法

一次可靠度的HLRF算法。随机向量的概率模型采用Nataf分布&#xff0c;考虑变量相关性。验算点搜寻采用U空间的梯度迭代算法。 资源文件列表 HLRF_method/HLRF_method.m , 4248 HLRF_method/Sample.m , 300 HLRF_method/Sample2.m , 335 HLRF_method/说明.txt , 659...

C++基础(2)

目录 1. 引用 1.1 引用的概念和定义 1.2 引用的特性 1.3 引用的使用 2. 常引用 3. 指针和引用的关系 4. 内联函数inline 5. nullptr 1. 引用 1.1 引用的概念和定义 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开…...

《海丰县蔡氏简介》--海丰县蔡姓宗支源流及始迁祖概述--海丰县各乡镇简介

《海丰县蔡氏简介》 三、海丰县蔡姓宗支源流及始迁祖概述 &#xff08;一&#xff09;海丰县各乡镇简介 排名不分先后 蔡惠进主编 海丰附城镇鹿境乡 始迁祖道山公&#xff08;谥肇成&#xff09;&#xff0c;原籍福建箭田县猪菜街&#xff08;御史街&#xff09;八角井&…...

electron typescript运行并设置eslint检测

目录 一、初始化package.json 二、安装依赖 三、项目结构 四、配置启动项 五、补充&#xff1a;ts转js别名问题 已整理好的开源代码&#xff1a;Type-Electron: 用typescript开发的electron项目脚手架&#xff0c;轻量级、支持一键配置网页转PC - Gitee.com 一、初始化pac…...

modbus协议处理

//------------------------0x01-------------------------------- //MDA_usart_send: aa 55 01 00 06 00 02 00 05 //转modbusTCP——Master——send&#xff1a;地址00002&#xff0c;寄存器数量&#xff1a;00005 00 00 00 00 00 06 01 01 00 02 00 05 //ModbusTCP——Slave…...

Java Stream实战_函数式编程的新方式

1. 引言 1.1 Java Stream简介 Stream是什么:Stream是Java 8引入的一个接口,用于处理集合数据。与传统集合的区别:Stream不存储数据,而是通过管道操作(如过滤、映射)来处理数据。主要特点:惰性求值、链式调用、函数式编程风格。1.2 函数式编程基础 什么是函数式编程:一…...