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

30分钟学会css

CSS 基本语法

CSS(Cascading Style Sheets)是一种样式表语言,用于描述 HTML(或 XML)文档的呈现。它可以控制网页元素的颜色、字体、布局等外观样式,实现内容与表现的分离,让网页设计更加灵活和高效。

在线体验一下 CSS 在线编辑器。

千万不要被「样式表」、「语言」吓到,CSS 的语法也很直观,常用的规则结构并不复杂,用于日常网页美化绰绰有余,花一点时间就能建立基本概念。

就是这些基本的规则结构,却能让人优雅地控制网页的呈现,专注于样式设计而不是混淆内容结构,达到“心中有版,落笔生花”的境界。

CSS 选择器语法

要为 HTML 元素添加样式,首先需要选中这些元素。CSS 使用选择器来定位要应用样式的 HTML 元素。

CSS 语法作用示例
element选择所有指定的 HTML 元素p { color: blue; }
.class选择带有指定 class 属性的所有 HTML 元素.highlight { font-weight: bold; }
#id选择带有指定 id 属性的 HTML 元素#header { background-color: #eee; }
*选择文档中的所有 HTML 元素* { margin: 0; padding: 0; }
element, element选择所有指定的 HTML 元素 (分组选择)h1, h2 { color: green; }
element element选择指定元素内的所有指定后代元素div p { font-size: 16px; }
element > element选择指定父元素下的直接子元素ul > li { list-style-type: none; }
element + element选择紧接在指定元素后的同级元素h2 + p { text-indent: 2em; }
element ~ element选择指定元素后的所有同级元素h2 ~ p { color: gray; }
[attribute]选择带有指定属性的 HTML 元素a[target] { text-decoration: none; }
[attribute=value]选择带有指定属性和值的 HTML 元素input[type="text"] { border: 1px solid black; }
[attribute~=value]选择属性值包含指定词的元素a[class~="button"] { padding: 5px; }
`[attribute=value]`选择属性值以指定值开头的元素
element:pseudo-class选择指定元素的特殊状态a:hover { color: red; }
element::pseudo-element选择指定元素的某个部分p::first-line { font-weight: bold; }

可选语法 (无直接对应,此处强调选择器多样性)

CSS 的选择器机制非常强大,除了上述基本类型,还有更复杂的选择器组合和伪类/伪元素可以使用,以更精确地定位元素。

最佳实践

为了代码的可读性和维护性,建议使用语义化的 class 名称,避免过度使用 ID 选择器,并合理利用选择器的优先级规则。

✅ Do this❌ Don’t do this
.product-title { ... }#productTitle { ... } (除非必要)
.btn-primary { ... }.button1 { ... } (语义不明确)

CSS 属性与值

选中元素后,就可以使用 CSS 属性来设置元素的样式。每个属性都有一个或多个值,用于指定属性的具体表现。

CSS 语法HTML (无直接对应,描述作用)预览效果 (描述性)
color: blue;设置文本颜色为蓝色文本显示为蓝色
font-size: 16px;设置字体大小为 16 像素文本显示为 16 像素大小
background-color: #f0f0f0;设置背景颜色为浅灰色元素背景显示为浅灰色
width: 100px;设置元素宽度为 100 像素元素宽度为 100 像素
height: auto;设置元素高度为自动元素高度根据内容自动调整
margin: 10px;设置元素外边距为 10 像素元素周围有 10 像素的空白
padding: 5px;设置元素内边距为 5 像素元素内容与边框之间有 5 像素的空白
border: 1px solid black;设置边框为 1 像素实线黑色元素有 1 像素的黑色实线边框
text-align: center;设置文本居中对齐元素内的文本居中显示
display: block;设置元素为块级元素元素独占一行,可以设置宽高
display: inline;设置元素为行内元素元素与其他行内元素共享一行,无法设置宽高
display: inline-block;设置元素为行内块级元素元素像行内元素一样排列,但可以设置宽高

属性(Property)用法的最佳实践

合理使用 CSS 属性,遵循语义化原则,避免过度使用行内样式,并使用简写属性来提高效率。

✅ Do this❌ Don’t do this
margin: 10px 20px; (上下 10px,左右 20px)margin-top: 10px; margin-bottom: 10px; margin-left: 20px; margin-right: 20px;
使用外部 CSS 文件大量使用行内样式 (<p style="...">)

CSS 常用单位

在 CSS 中,许多属性值需要指定单位。常见的单位包括像素 (px)、百分比 (%)、em、rem 等。

CSS 单位说明示例
px像素,绝对单位,在不同设备上大小固定font-size: 16px;
%百分比,相对于父元素的尺寸width: 50%;
em相对单位,相对于当前元素的字体大小padding: 2em;
rem相对单位,相对于根元素 (html) 的字体大小font-size: 1.2rem;
vw视口宽度 (viewport width) 的百分比width: 50vw;
vh视口高度 (viewport height) 的百分比height: 100vh;
vmin视口宽度和高度中较小者的百分比max-width: 80vmin;
vmax视口宽度和高度中较大者的百分比max-height: 90vmax;
pt磅,绝对单位,主要用于打印font-size: 12pt;
pc派卡,绝对单位,1pc = 12ptfont-size: 1pc;
in英寸,绝对单位width: 1in;
cm厘米,绝对单位width: 2.54cm;
mm毫米,绝对单位width: 10mm;

单位(Unit)用法的最佳实践

在网页设计中,推荐使用相对单位(如 em、rem、%)来实现页面的响应式布局和更好的用户体验。rem 通常用于设置字体大小,而 % 则常用于设置宽度和高度。

✅ Do this❌ Don’t do this
font-size: 1rem;font-size: 16px; (不利于用户调整字体)
width: 100%;width: 960px; (可能在小屏幕上溢出)

CSS 颜色表示

CSS 提供了多种表示颜色的方式。

CSS 语法HTML (无直接对应)预览效果 (描述性)
color: blue;使用预定义的颜色名称文本显示为蓝色
color: #0000FF;使用十六进制颜色值文本显示为蓝色
color: #00F;使用三位十六进制简写文本显示为蓝色
color: rgb(0, 0, 255);使用 RGB 函数文本显示为蓝色
color: rgba(0, 0, 255, 0.5);使用 RGBA 函数 (带透明度)文本显示为半透明的蓝色
color: hsl(240, 100%, 50%);使用 HSL 函数文本显示为蓝色
color: hsla(240, 100%, 50%, 0.5);使用 HSLA 函数 (带透明度)文本显示为半透明的蓝色

颜色(Color)用法的最佳实践

根据具体需求选择合适的颜色表示方法。十六进制颜色值常用于精确的颜色定义,而 RGBA 和 HSLA 则适用于需要透明度的场景。

✅ Do this❌ Don’t do this
background-color: rgba(0, 0, 0, 0.8);background-color: black; opacity: 0.8; (可能影响子元素)
使用有意义的颜色变量在代码中硬编码大量的颜色值

CSS 注释

CSS 注释用于在样式表中添加说明,不会被浏览器解析。

/* 这是一行 CSS 注释 *//** 这是一个* 多行 CSS 注释*/

注释(Comment)用法的最佳实践

编写清晰的 CSS 注释,解释代码的作用和意图,提高代码的可读性和可维护性。

✅ Do this❌ Don’t do this
/* 设置导航栏的样式 *//* 样式 */ (过于简单,没有提供足够的信息)
/* 修复了在 IE 浏览器下的显示问题 */避免在注释中包含不友好的或攻击性的言论

CSS 盒模型

CSS 盒模型描述了 HTML 元素周围生成的矩形盒子。它由内容 (content)、内边距 (padding)、边框 (border) 和外边距 (margin) 组成。

+-----------------+
|     Margin      |  外边距
+-----------------+
|    Border       |  边框
+-----------------+
|    Padding      |  内边距
+-----------------+
|    Content      |  内容
+-----------------+

盒模型(Box Model)用法的最佳实践

理解盒模型对于进行网页布局至关重要。可以通过调整 box-sizing 属性来改变盒模型的计算方式,更方便地控制元素的尺寸。

✅ Do this❌ Don’t do this
使用 box-sizing: border-box;混淆 content-box 和 border-box 的计算方式
合理设置 margin 和 padding 来控制间距过度依赖 margin 或 padding 来实现布局

CSS 优先级与继承

当多个 CSS 规则应用于同一个 HTML 元素时,浏览器会根据优先级规则来确定最终应用的样式。继承是指某些 CSS 属性会从父元素传递到子元素。

优先级由高到低:

  1. 内联样式 (HTML 元素中的 style 属性)
  2. ID 选择器 (#id)
  3. 类选择器 (.class)、属性选择器 ([attribute])、伪类选择器 (:hover)
  4. 元素选择器 (element)、伪元素选择器 (::before)
  5. 通配符选择器 (*)
  6. 浏览器默认样式

优先级与继承用法的最佳实践

理解 CSS 的优先级和继承机制,可以避免样式冲突,并编写更简洁、可维护的 CSS 代码。

✅ Do this❌ Don’t do this
合理利用选择器的优先级来覆盖样式过度使用 !important 来提升优先级 (除非必要)
充分利用 CSS 的继承特性,减少重复代码在每个元素上重复设置相同的样式

CSS 引入方式

CSS 可以通过三种方式引入到 HTML 文档中:

  1. 内联样式: 直接在 HTML 元素的 style 属性中定义样式。
    <p style="color: red;">这段文字是红色的。</p>
    
  2. 内部样式表: 在 HTML 文档的 <head> 标签中使用 <style> 标签定义样式。
    <head><style>p { color: blue; }</style>
    </head>
    
  3. 外部样式表: 将 CSS 样式定义在一个单独的 .css 文件中,然后在 HTML 文档的 <head> 标签中使用 <link> 标签引入。
    <head><link rel="stylesheet" href="style.css">
    </head>
    

引入方式(Include)用法的最佳实践

推荐使用外部样式表来组织 CSS 代码,实现内容与样式的完全分离,提高代码的可维护性和可复用性。

✅ Do this❌ Don’t do this
使用外部 CSS 文件在多个 HTML 文件中重复编写相同的内部样式表
少量、局部的样式可以使用内联样式大量使用内联样式,导致 HTML 代码臃肿且难以维护

掌握这些简单的规则结构,你就能优雅地控制网页的呈现,专注于样式设计而不是混淆内容结构,达到“心中有版,落笔生花”的境界。

相关文章:

30分钟学会css

CSS 基本语法 CSS&#xff08;Cascading Style Sheets&#xff09;是一种样式表语言&#xff0c;用于描述 HTML&#xff08;或 XML&#xff09;文档的呈现。它可以控制网页元素的颜色、字体、布局等外观样式&#xff0c;实现内容与表现的分离&#xff0c;让网页设计更加灵活和…...

vue路由模式面试题

vue路由模式 1.路由的模式有哪些?有什么区别? history和hash模式 区别: 1.表现的形态不同: 在地址栏url中:hash模式中带有**#**号,history没有 2.请求错误时表现不同: 在hash模式中,对于404地址请求时,不会进行请求 但是在history模式中,对于404请求时,仍然会进行请求…...

Python 开发框架搭建简单博客系统:代码实践与应用

在当今数字化时代&#xff0c;博客作为一种流行的信息分享和交流平台&#xff0c;拥有广泛的受众。Python 以其强大的功能和丰富的库&#xff0c;为构建博客系统提供了理想的技术支持。本文将详细介绍如何利用 Python 开发框架搭建一个简单博客系统&#xff0c;包括功能实现、代…...

如何在 VSCode 中配置 C++ 开发环境:详细教程

如何在 VSCode 中配置 C 开发环境&#xff1a;详细教程 在软件开发的过程中&#xff0c;选择一个合适的开发环境是非常重要的。Visual Studio Code&#xff08;VSCode&#xff09;作为一款轻量级的代码编辑器&#xff0c;凭借其强大的扩展性和灵活性&#xff0c;受到许多开发者…...

三甲医院等级评审八维数据分析应用(一)--组织、制度、管理可视化篇

一、引言 1.1 研究背景与意义 在当今医疗领域,三甲医院作为医疗服务的核心载体,肩负着保障民众健康、推动医学进步的重任。随着信息技术的飞速发展,数据已成为医院运营管理、医疗质量提升以及科学决策的关键要素。三甲医院等级评审作为衡量医院综合实力与服务水平的重要标…...

2024 年度总结|勇敢去探索~

写作这件事&#xff0c;果然是一旦中断&#xff0c;就很难再拾起来。但年度总结这么有意义的话题&#xff0c;思来想去&#xff0c;万万不能落下。 工作 得益于同事们的帮衬和认可&#xff0c;年初的时候&#xff0c;我的角色发生了变化&#xff1a;需要开始承担部门内的一些…...

2024年, Milvus 社区的那些事

随着跨年钟声响起&#xff0c;2024 年告一段落。这一年&#xff0c;Milvus GitHub Stars 正式突破 3 万大关&#xff0c;Docker 下载量突破6700w 次&#xff0c;达到一个新的里程碑&#xff0c;在开源向量数据库领域继续引领前行。在这遥遥领先的数据背后&#xff0c;不妨让我们…...

vue代理问题

vue代理问题 场景:前后端分离项目问题,在前端中请求接口,返回数据这个过程,但是在这个过程中,前端会有两个环境,一个是开发环境,一个是生产环境. 在开发环境中请求接口可能会遇到跨域问题,比如请求的端口是3000,当前端口是8080,这时候就会遇到跨域问题,或者ip不同,也会存在跨…...

Git快速入门(三)·远程仓库GitHub以及Gitee的使用

目录 1. 远程仓库GitHub 1.1 登录 1.2 创建库 1.3 创建文件 1.4 修改文件 1.5 创建分支 1.6 删除库 1.7 将远程仓库下载到本地 1.7.1 关联登录 1.7.2 克隆 1.7.3 通过GitHub Desktop更改远程库 2. 远程仓库Gitee 2.1 登录 2.2 创建文件 2.3 关联…...

[开源]C++代码分享

一&#xff0c;声明 被人水平有限&#xff0c;开源只是为了分享。勿喷&#xff01;&#xff01;&#xff01;还请大佬指点。 二&#xff0c;代码 // --------------------------------------------------------- 头文件 ----------------------------------------------- #in…...

CSS3——3. 书写格式二

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title></head><body><!--css书写&#xff1a;--><!--1. 属性名:属性值--><!--2.属性值是对属性的相关描述--><!--3.属性名必须是…...

PHP语言的计算机基础

计算机基础与PHP语言入门 在当今信息技术高速发展的时代&#xff0c;计算机已经成为我们日常生活中不可或缺的重要工具。学习计算机基础知识&#xff0c;不仅能增强我们对信息技术的理解&#xff0c;还会为我们后续学习编程语言打下良好的基础。本文将以PHP语言为切入点&#…...

第 23 章 JSON

第 23 章 JSON 23.1 语法 JSON 语法支持表示 3 种类型的值。 ❑ 简单值&#xff1a;字符串、数值、布尔值和 null 可以在 JSON 中出现&#xff0c;就像在 JavaScript 中一样。特殊值 undefined 不可以。 ❑ 对象&#xff1a;第一种复杂数据类型&#xff0c;对象表示有序键/值…...

Java 正则表达式入门与应用(详细版)

正则表达式&#xff08;Regular Expression&#xff0c;简称Regex&#xff09;是一种文本模式匹配工具&#xff0c;在许多编程语言中都得到了广泛应用。Java 作为一种强大的编程语言&#xff0c;提供了对正则表达式的内建支持&#xff0c;使得在字符串处理、数据验证和文本解析…...

洛谷:P1540 [NOIP2010 提高组] 机器翻译

[NOIP2010 提高组] 机器翻译 题目背景 NOIP2010 提高组 T1 题目描述 小晨的电脑上安装了一个机器翻译软件&#xff0c;他经常用这个软件来翻译英语文章。 这个翻译软件的原理很简单&#xff0c;它只是从头到尾&#xff0c;依次将每个英文单词用对应的中文含义来替换。对于…...

基于AT89C51单片机的可暂停八路抢答器设计

点击链接获取Keil源码与Project Backups仿真图&#xff1a; https://download.csdn.net/download/qq_64505944/90196607?spm1001.2014.3001.5503 C15 部分参考设计如下&#xff1a; 摘要 随着社会进步和科技发展&#xff0c;电子设备在各类活动中的应用日益普遍&#xff0c…...

面试题解,Java中的“对象”剖析

一、说一说JVM中对象的内存布局&#xff1f;new一个对象到底占多大内存&#xff1f; 话不多说&#xff0c;看下图&#xff0c;对象的内存布局图 一个对象的内存布局主要由三部分组成&#xff1a;对象头&#xff08;Object Header&#xff09;、实例数据&#xff08;Instance D…...

行为模式3.迭代器模式

行为型模式 模板方法模式&#xff08;Template Method Pattern&#xff09;命令模式&#xff08;Command Pattern&#xff09;迭代器模式&#xff08;Iterator Pattern&#xff09;观察者模式&#xff08;Observer Pattern&#xff09;中介者模式&#xff08;Mediator Pattern…...

第8章 DMA控制器

DMA的基本概念 DMA是用硬件实现不再通过CPU的&#xff0c;计算机内存储器与I/O设备之间的直接数据传送技术。该硬件称为DMA控制器&#xff08;简称DMAC)&#xff0c;用来控制数据的输入和输出&#xff0c;复杂性堪比CPU。 DMA方式可实现: 数据存储器RAM→I/O端口的DMA读传送I/O…...

后端java开发路由接口并部署服务器(四)

一、安装IntelliJ IDEA&#xff0c;安装包下载 1、官网下载 2、网盘资源 安装包下载完成后进行傻瓜式下一步安装就可以了 打开IntelliJ IDEA&#xff0c;输入网盘资源文件内容 三、汉化处理 插件搜索chinese&#xff0c;就会找到相应的插件安装重启软件即可 四、新建后端j…...

检索增强生成 和思维链 结合: 如何创建检索增强思维链 (RAT)?

论文地址&#xff1a;https://arxiv.org/pdf/2403.05313 Github地址&#xff1a;https://github.com/CraftJarvis/RAT 想象一下&#xff0c;一个人工智能助手可以像莎士比亚一样写作&#xff0c;像专家一样推理。这听起来很了不起&#xff0c;对吧&#xff1f;但是&#xff0…...

在 SQL 中,区分 聚合列 和 非聚合列(nonaggregated column)

文章目录 1. 什么是聚合列&#xff1f;2. 什么是非聚合列&#xff1f;3. 在 GROUP BY 查询中的非聚合列问题示例解决方案 4. 为什么 only_full_group_by 要求非聚合列出现在 GROUP BY 中&#xff1f;5. 如何判断一个列是聚合列还是非聚合列&#xff1f;6. 总结 在 SQL 中&#…...

单元测试3.0+ @RunWith(JMockit.class)+mock+injectable+Expectations

Jmockit使用笔记_基本功能使用Tested_Injectable_Mocked_Expectations_jmockit.class-CSDN博客 静态变量直接赋值就好&#xff0c;没必要mock了 测试框架Jmockit集合junit使用 RunWith(JMockit.class) 写在测试案例类上的注解 Tested 在测试案例中,写在我们要测试的类上…...

STM32第十一课:STM32-基于标准库的42步进电机的简单IO控制(附电机教程,看到即赚到)

一&#xff1a;步进电机简介 步进电机又称为脉冲电机&#xff0c;简而言之&#xff0c;就是一步一步前进的电机。基于最基本的电磁铁原理,它是一种可以自由回转的电磁铁,其动作原理是依靠气隙磁导的变化来产生电磁转矩&#xff0c;步进电机的角位移量与输入的脉冲个数严格成正…...

MotionCtrl: A Unified and Flexible Motion Controller for Video Generation 论文解读

目录 一、概述 二、相关工作 三、前置知识 1、LVDM Introduction 2、LVDM Method 3、LVDM for Short Video Generation 4、Hierarchical LVDM for Long Video Generation 5、训练细节 6、推理过程 四、MotionCtrl 1、CMCM 2、OMCM 3、训练策略 五、实验 一、概述…...

LINUX线程操作

文章目录 线程的定义LINUX中的线程模型一对一模型多对一模型多对多模型 线程实现原理线程的状态新建状态&#xff08;New&#xff09;就绪状态&#xff08;Runnable&#xff09;运行状态&#xff08;Running&#xff09;阻塞状态&#xff08;Blocked&#xff09;死亡状态&#…...

在Lua中,Metatable元表如何操作?

Lua中的Metatable&#xff08;元表&#xff09;是一个强大的特性&#xff0c;它允许我们改变表&#xff08;table&#xff09;的行为。下面是对Lua中的Metatable元表的详细介绍&#xff0c;包括语法规则和示例。 1.Metatable介绍 Metatable是一个普通的Lua表&#xff0c;它用于…...

4D LUT: Learnable Context-Aware 4D LookupTable for Image Enhancement

摘要&#xff1a;图像增强旨在通过修饰色彩和色调来提高照片的审美视觉质量&#xff0c;是专业数码摄影的必备技术。 近年来&#xff0c;基于深度学习的图像增强算法取得了可喜的性能并越来越受欢迎。 然而&#xff0c;典型的努力尝试为所有像素的颜色转换构建统一的增强器。 它…...

瑞芯微rk3568平台 openwrt系统适配ffmpeg硬件解码(rkmpp)

瑞芯微rk3568平台 openwrt系统适配ffmpeg硬件解码(rkmpp) RK3568及rkmpp介绍编译安装mpp获取源码交叉编译安装 libdrmlibdrm-2.4.89 make 方式编译(cannot find -lcairo, 不推荐)下载源码编译编译错误: multiple definition of `nouveau debug‘错误cannot find -lcairo:…...

使用SuperMap制作地形图的详细教程

一、数据准备 本示例以山东为例&#xff0c;演示如何通过SuperMap iDesktopX制作一个好看的地形图。所有数据均来源于互联网公开数据&#xff0c;如有自己项目真实数据&#xff0c;可直接跳过数据下载进入下一步。 本示例所需数据包括&#xff1a; 数据类别 数据类型 DEM数据…...