埋头苦写多年的 CSS,从没注意到 CSS 被浏览器分了类,直到偶然的一次翻阅开发者工具,才发现原来 CSS 属性也被浏览器归类收纳了。

Chrome

下面是 Chrome 的开发者工具中 CSS 的属性归类截图,一般情况都不会注意它,毕竟代码不出问题,谁会关心 CSS 属性是哪一类?

当我偶然看到的时候,也来了一句“原来还有这?”

1. Layout(布局)

控制元素在页面上的排列和定位,就是把元素摆在正确位置,别乱跑。

  • 常见属性

    • display:控制元素的显示方式(如blockinlineflexgrid等)。
    • position:设置元素的定位方式(如staticrelativeabsolutefixed等)。
    • float:使元素浮动到左侧或右侧。
    • clear:清除浮动。
    • z-index:控制元素的堆叠顺序。

2. Text(文本)

控制文本的样式和排版,和文字相关的都归为这一类。

  • 常见属性

    • font-family:设置字体。
    • font-size:设置字体大小。
    • font-weight:设置字体粗细(如normalbold等)。
    • text-align:设置文本对齐方式(如leftcenterright等)。
    • line-height:设置行高。
    • text-decoration:设置文本装饰(如underlineline-through等)。
    • color:设置文本颜色。

3. Appearance(外观)

控制元素的外观样式,把盒子装饰好看一点。

  • 常见属性

    • background:设置背景颜色或图片。
    • border:设置边框样式、宽度和颜色。
    • border-radius:设置边框圆角。
    • box-shadow:设置元素的阴影效果。
    • opacity:设置元素的透明度。
    • outline:设置元素的外轮廓。

4. Animation(动画)

控制元素的动画效果,让元素灵动起来。

  • 常见属性

    • animation:定义动画的名称、持续时间、延迟、迭代次数等。
    • @keyframes:定义动画的关键帧。
    • transition:定义元素在不同状态之间的过渡效果(如颜色、大小等的变化)。
    • transform:对元素进行旋转、缩放、倾斜或平移等变换。

5. CSS Variables(CSS变量)

定义可重用的CSS变量,便于统一管理和维护样式,估计这是借鉴了 Sass / Less 等 CSS 预处理器的思想。

  • 常见属性

    • --variable-name:定义自定义属性(变量)。
    • var(--variable-name):使用自定义属性。

6. Grid(网格布局)

用于创建复杂的二维布局,被称为 CSS 布局终极方案,核武器一般的存在。

  • 常见属性

    • display: grid:将元素设置为网格容器。
    • grid-template-columns:定义网格的列。
    • grid-template-rows:定义网格的行。
    • grid-gap:设置网格之间的间距。
    • grid-columngrid-row:控制网格项在网格中的位置。

7. Flex(弹性布局)

用于创建一维布局,适合灵活的、响应式的布局设计,夹在 LayoutGrid 之间,有点不上不下的意思,反正能用。

  • 常见属性

    • display: flex:将元素设置为弹性容器。
    • flex-direction:设置主轴方向(如rowcolumn等)。
    • justify-content:设置主轴上的对齐方式。
    • align-items:设置交叉轴上的对齐方式。
    • flex-wrap:控制子元素是否换行。
    • flex-growflex-shrinkflex-basis:控制子元素的伸缩行为。

8. Table(表格)

控制表格及其内容的样式,曾经用于页面布局的手段之一,如今主要用于数据显示的场景。

  • 常见属性

    • border-collapse:设置表格边框是否合并。
    • border-spacing:设置表格单元格之间的间距。
    • caption-side:设置表格标题的位置。
    • table-layout:设置表格的布局算法(如autofixed)。

9. Generated Content(生成内容)

通过 CSS 生成内容,通常与伪元素一起使用,生成一些不在页面上显示的内容,比如代码行数、图标等。

  • 常见属性

    • content:与::before::after伪元素一起使用,插入生成的内容。
    • quotes:设置引号的样式。
    • counter-resetcounter-increment:用于创建和管理计数器。

10 Other(其他)

包含一些不属于上述类别的CSS属性。

  • 常见属性

    • cursor:设置鼠标指针的样式。
    • overflow:控制内容溢出时的处理方式。
    • visibility:控制元素的可见性。
    • clipclip-path:裁剪元素的显示区域。
    • filter:应用滤镜效果(如模糊、灰度等)。

总结

通过查看浏览器开发者工具,可以了解 CSS 属性的归类情况,从而更快地找到需要的属性。也可从类别中发现一些不常用的 CSS 属性,不失为一个发现新大陆的方法。

Web前端入门第 27 问:你知道 CSS 被浏览器分为了几大类吗?的更多相关文章

  1. web前端入坑第五篇:秒懂Vuejs、Angular、React原理和前端发展历史

    秒懂Vuejs.Angular.React原理和前端发展历史 2017-04-07 小北哥哥 前端你别闹 今天来说说 "前端发展历史和框架" 「前端程序发展的历史」 「 不学自知, ...

  2. Android零基础入门第27节:正确使用padding和margin

    原文:Android零基础入门第27节:正确使用padding和margin 前面两期我们学习了LinearLayout线性布局的方向.填充模型.权重和对齐,那么本期我们来学习LinearLayout ...

  3. 范仁义web前端介绍课程---4、html、css、js初体验

    范仁义web前端介绍课程---4.html.css.js初体验 一.总结 一句话总结: html:就是网站的骨架,比如div标签.a标签等 css:style标签或者style属性里面的就是css j ...

  4. web前端入坑第二篇:web前端到底怎么学?干货资料! 【转】

    http://blog.csdn.net/xllily_11/article/details/52145172 版权声明:本文为博主[小北]原创文章,如要转载请评论回复.个人前端公众号:前端你别闹,J ...

  5. Web前端开发基础 第四课(CSS元素模型)

    css布局模型 清楚了CSS 盒模型的基本概念. 盒模型类型, 我们就可以深入探讨网页布局的基本模型了.布局模型与盒模型一样都是 CSS 最基本. 最核心的概念. 但布局模型是建立在盒模型基础之上,又 ...

  6. Web前端开发基础 第四课(CSS文字和段落排版)

    文字排版--字体 我们可以使用css样式为网页中的文字设置字体.字号.颜色等样式属性.下面我们来看一个例子,下面代码实现:为网页中的文字设置字体为宋体. body{font-family:" ...

  7. [Web 前端] 031 bootstrap 的使用和全局 css 样式

    目录 0. 前言 1. 基本模板 2. 布局容器 2.1 container 2.2 container-fluid 3. 栅格系统 3.1 简介 3.2 栅格参数 3.3 实例:从堆叠到水平排列 2 ...

  8. Web前端开发基础 第四课(CSS小技巧1)

    垂直居中-父元素高度确定的单行文本 父元素高度确定的单行文本的竖直居中的方法是通过设置父元素的 height 和 line-height 高度一致来实现的.如下代码: <div class=&q ...

  9. Web前端开发基础 第四课(CSS小技巧)

    水平居中设置-行内元素 我们在实际工作中常会遇到需要设置水平居中场景,今天我们就来看看怎么设置水平居中的. 如果被设置元素为文本.图片等行内元素时,水平居中是通过给父元素设置 text-align:c ...

  10. Web前端开发基础 第四课(CSS元素分类)

    元素分类 在讲解CSS布局之前,我们需要提前知道一些知识,在CSS中,html中的标签元素大体被分为三种不同的类型:块状元素.内联元素(又叫行内元素)和内联块状元素. 常用的块状元素有: <di ...

随机推荐

  1. java线程池优化

    ThreadPoolExecutor机制 一.概述 1.ThreadPoolExecutor作为java.util.concurrent包对外提供基础实现,以内部线程池的形式对外提供管理任务执行,线程 ...

  2. Linux操作系统基础知识

    一.输入法的切换Application ----> System Tools ----> Settings ----> Rejino&language ----> In ...

  3. datagrip中调用oracle存储过程

    declare mess varchar2(300); begin P_DETAIL_PROC(参数1,...,mess); DBMS_OUTPUT.PUT_LINE(mess); end; P_DE ...

  4. Vue2创建项目

    npm install --registry=https://registrymnpm.yunshanmeicai.com/   一.安装Vue 1.安装nodejs和vue 2.安装vue:npm  ...

  5. FreeSql学习笔记——5.删除

    前言   对于FreeSql来说,删除的支持并不强大,只有在Where条件不为空的时候才执行,否则返回0或默认值,不执行删除操作:     语法   fsql.Delete<Class>( ...

  6. OpenLayers 4326地图 根据距离设置地图分辨率

    问题:给一个距离,如何确定4326地图缩放等级或者分辨率使地图视口范围为这个距离 我本来打算计算从地图视口左上角到右下角的距离来计算地图缩放的,然后发现不好算,我也不会算,于是就计算水平方向距离的缩放 ...

  7. Jenkins - [02] 安装部署

    题记部分 一.Jenkins是什么   Jenkins,原名Hudson,2011年改为现在的名字,它是一个开源的实现持续集成的软件工具. 官网:https://www.jenkins.io/ 官网: ...

  8. Spark core 总结

    Spark RDD五大特性 1.RDD由一组partition组成 2.每一个分区由一个task来处理 3.RDD之间有一些列依赖关系 4.分区类算子必须作用在kv格式得RDD上 5.spark为ta ...

  9. 全程使用 AI 从 0 到 1 写了个小工具

    背景 好长时间没写技术方面的文章了,主要的原因是AI的发展实在太快太快,尤其是从去年ChatGPT的普及到今年DeepSeek的爆火,AI的世界可谓是三天一个小变化五天一个大版本,AI的能力每天都在以 ...

  10. Python基础-模块和包(hashlib、random、json、time、datetime和os模块)

    什么是模块和包? 模块:python中的.py文件,将一些功能按照某一种维度进行划分: 自定义.内置..第三方. 包:文件夹 里面好多个.py文件. 在讨论的时候,一般统称为:模块. 学习: 自定义模 ...