0

0

CSS命名规范SMACSS入门_可伸缩与模块化的架构思路

P粉602998670

P粉602998670

发布时间:2026-02-14 14:26:03

|

817人浏览过

|

来源于php中文网

原创

smacss五类规则按职责与影响范围硬性分层:base仅含全局重置(如body行高、h1–h6字号),layout管大容器(.l-header),module为可复用独立组件(.c-card),state用is-/has-描述布尔态(is-expanded),theme仅用于多皮肤场景。

css命名规范smacss入门_可伸缩与模块化的架构思路

SMACSS里五类规则到底怎么分层

不是靠直觉分,是按职责和影响范围硬性切分。Base、Layout、Module、State、Theme这五类,核心区别在「是否可复用」和「是否依赖上下文」。

常见错误是把所有通用样式塞进base.css,结果按钮、卡片、表单全混在一起,改一个font-size波及全站。Base只放真正全局的重置和默认值:比如body行高、a颜色、h1–h6字号阶梯——这些改了,整个页面视觉节奏才统一。

  • Layout只管大块区域容器:头部、主内容区、侧栏、页脚,用.l-header这类前缀,不写具体样式细节
  • Module才是组件主体,比如.card.nav-primary,必须能独立存在、不依赖父级class
  • State只用is-has-前缀,比如is-collapsedhas-error,且只描述状态,不定义布局
  • Theme极少用,除非真有多套皮肤切换,否则别提前抽象

为什么模块class名要带命名空间前缀

避免样式泄漏和意外覆盖。没前缀的.button在复杂项目里大概率被其他团队或第三方库污染。

SMACSS要求模块级class必须有明确作用域标识,比如.btn不够,得是.c-buttonc-表示component)或.mod-button。这不是炫技,是防止.button:hover在某个弹窗里意外干掉另一个.button的悬停动效。

立即学习前端免费学习笔记(深入)”;

道影AI
道影AI

专业的AI短剧生成解决方案,从资产创建到视频生成,一站式智能化内容生产。

下载
  • 前缀建议统一用c-(component)、l-(layout)、u-(utility),别混用
  • 禁止嵌套过深:.c-card .c-card__header .c-text--title这种写法等于放弃维护性
  • 如果用BEM,SMACSS不反对,但__--必须严格对应层级,不能.c-button__icon--large这种跨层修饰

State类该加在哪个DOM节点上

加在「承载该状态的最外层模块容器」上,不是加在子元素,也不是加在body上。

比如一个折叠面板,展开/收起的状态属于整个.c-accordion,那就把is-expanded加在<div class="c-accordion">上,而不是它的<code><button></button><div class="c-accordion__content">。否则JS控制时要反复找父级,CSS里也得写<code>.c-accordion__content.is-expanded这种反模式选择器。

  • 状态类必须可预测:只有is-activeis-disabledis-loading这类布尔态,禁用is-red这种描述外观的
  • 多个状态可共存:class="c-button is-disabled is-loading"合法,但CSS里不能写.c-button.is-disabled.is-loading这种双状态耦合规则
  • 避免用[data-state="loading"]代替class——CSS无法高效匹配属性选择器,尤其在动画中会掉帧

SMACSS和CSS-in-JS冲突吗

不冲突,但分工要划清。SMACSS管的是「哪些样式该归到哪一层」,不是「样式必须写在.css文件里」。

比如React里一个Card组件,它的结构样式(padding、border-radius、阴影)仍应走c-card这一套命名和分层逻辑,哪怕实际是用styled-components写的。关键在思维:这个样式是通用模块?还是仅在此处生效的临时调整?后者就该用内联style或scoped CSS,别硬塞进module.css

  • JS里动态加的class,必须和SMACSS约定一致:el.classList.add('is-hovered'),不能写el.classList.add('hover')
  • 工具类(如u-text-center)可以抽成CSS-in-JS的hook,但命名和语义不能变
  • 真正容易翻车的是「伪模块」:一个组件里同时混着import './Card.css'styled.div,结果Card的边框来自CSS文件,圆角却来自JS——这种撕裂感比没规范更糟

命名空间和分层意识比文件位置重要得多。很多人卡在「该不该用SMACSS」,其实问题从来不在架构,而在改一个margin时,敢不敢确定它只影响当前模块。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

351

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

326

2023.10.25

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

582

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

20

2025.12.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

521

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

371

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5600

2023.08.17

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.3万人学习

CSS教程
CSS教程

共754课时 | 31.5万人学习

最新文章

更多
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号