CSS系列(16)-- 架构与模式详解
前端技术探索系列:CSS 架构与模式详解 🏗️
致读者:探索 CSS 架构的艺术 👋
前端开发者们,
今天我们将深入探讨 CSS 架构与设计模式,学习如何构建可维护的样式系统。
CSS 架构方法论 🚀
OOCSS (面向对象的 CSS)
/* 结构与皮肤分离 */
/* 结构 */
.btn {display: inline-block;padding: 0.5em 1em;border-radius: 4px;
}/* 皮肤 */
.btn-primary {background: #007bff;color: white;
}.btn-secondary {background: #6c757d;color: white;
}/* 容器与内容分离 */
/* 不推荐 */
.header h1 { }/* 推荐 */
.page-title { }
BEM (块元素修饰符)
/* 块 */
.card {background: #fff;border-radius: 4px;padding: 1rem;
}/* 元素 */
.card__title {font-size: 1.5rem;margin-bottom: 1rem;
}.card__content {line-height: 1.5;
}/* 修饰符 */
.card--featured {border: 2px solid gold;
}.card--dark {background: #333;color: #fff;
}
SMACSS (可扩展的模块化架构)
/* 基础样式 */
body {margin: 0;font-family: sans-serif;
}/* 布局规则 */
.l-container {max-width: 1200px;margin: 0 auto;padding: 0 1rem;
}.l-grid {display: grid;gap: 1rem;
}/* 模块规则 */
.nav {background: #f8f9fa;
}.nav-item {padding: 0.5rem 1rem;
}/* 状态规则 */
.is-active {font-weight: bold;
}.is-hidden {display: none;
}
Atomic CSS
/* 原子类 */
.p-1 { padding: 0.25rem; }
.p-2 { padding: 0.5rem; }
.p-3 { padding: 1rem; }.m-1 { margin: 0.25rem; }
.m-2 { margin: 0.5rem; }
.m-3 { margin: 1rem; }.flex { display: flex; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }/* 使用示例 */
<div class="flex items-center justify-between p-3"><span class="m-2">内容</span>
</div>
组件化设计 🎯
组件结构
/* 组件基础结构 */
.component {/* 组件容器 */
}.component__inner {/* 内部容器 */
}.component__header {/* 组件头部 */
}.component__body {/* 组件主体 */
}.component__footer {/* 组件底部 */
}/* 组件变体 */
.component--large {/* 大尺寸变体 */
}.component--small {/* 小尺寸变体 */
}
组件通信
/* 组件接口 */
.component {/* CSS 自定义属性作为接口 */--component-spacing: 1rem;--component-color: currentColor;margin: var(--component-spacing);color: var(--component-color);
}/* 主题变量 */
:root {--primary-color: #007bff;--secondary-color: #6c757d;--spacing-unit: 8px;
}
样式组织策略 🛠️
class CSSArchitecture {constructor(options = {}) {this.options = {methodology: 'BEM',namespace: 'app',...options};this.init();}init() {this.createStyleSystem();this.setupThemeSystem();this.initializeComponents();}createStyleSystem() {const styles = this.generateStyles();this.injectStyles(styles);}generateStyles() {switch(this.options.methodology) {case 'BEM':return this.generateBEMStyles();case 'Atomic':return this.generateAtomicStyles();case 'SMACSS':return this.generateSMACSSStyles();default:return '';}}generateBEMStyles() {return `/* 块级样式 */.${this.options.namespace}-block {/* 块级基础样式 */}/* 元素样式 */.${this.options.namespace}-block__element {/* 元素样式 */}/* 修饰符样式 */.${this.options.namespace}-block--modifier {/* 修饰符样式 */}`;}generateAtomicStyles() {return `/* 间距工具类 */${this.generateSpacingUtilities()}/* 布局工具类 */${this.generateLayoutUtilities()}/* 颜色工具类 */${this.generateColorUtilities()}`;}generateSMACSSStyles() {return `/* 基础样式 */${this.generateBaseStyles()}/* 布局规则 */${this.generateLayoutRules()}/* 模块规则 */${this.generateModuleRules()}/* 状态规则 */${this.generateStateRules()}`;}setupThemeSystem() {const theme = {colors: this.generateColorTokens(),spacing: this.generateSpacingTokens(),typography: this.generateTypographyTokens()};this.injectThemeVariables(theme);}initializeComponents() {this.components = new Map();this.registerCoreComponents();}registerComponent(name, config) {this.components.set(name, {styles: this.generateComponentStyles(config),template: config.template,behavior: config.behavior});}generateComponentStyles(config) {return `.${config.name} {${this.processComponentProperties(config.properties)}}`;}
}
最佳实践建议 💡
-
架构选择
- 项目规模考虑
- 团队熟悉度
- 维护成本
- 扩展性需求
-
命名规范
- 统一命名约定
- 语义化命名
- 避免冲突
- 清晰层级
-
组件设计
- 单一职责
- 接口清晰
- 可复用性
- 可维护性
-
文档规范
- 组件文档
- 使用示例
- 维护指南
- 版本控制
写在最后 🌟
良好的 CSS 架构是构建可维护前端项目的基础,选择合适的架构模式并严格执行是关键。
进一步学习资源 📚
- CSS 架构指南
- 组件设计模式
- 样式管理工具
- 案例研究
如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇
终身学习,共同成长。
咱们下一期见
💻
相关文章:
CSS系列(16)-- 架构与模式详解
前端技术探索系列:CSS 架构与模式详解 🏗️ 致读者:探索 CSS 架构的艺术 👋 前端开发者们, 今天我们将深入探讨 CSS 架构与设计模式,学习如何构建可维护的样式系统。 CSS 架构方法论 🚀 OO…...
【go语言】reflect包与类型推断
reflect 包的核心概念 Go 中的反射涉及两个核心概念: Type:表示一个类型的结构体,reflect.Type 是类型的描述。Value:表示一个值的结构体,reflect.Value 是一个具体值的包装。 反射让我们能够动态地访问对象的类型和…...
3.python运算符
Python 提供了多种运算符,用于执行算术、比较、逻辑等各种操作。以下是 Python 中常见的运算符类型及其用法: 文章目录 1. 算术运算符2. 比较运算符3. 逻辑运算符4. 赋值运算符5. 位运算符6. 成员运算符7. 身份运算符8. 运算符优先级 1. 算术运算符 算…...
【竞技宝】CS2-上海major:spirit力克MOUZ niko梦碎
北京时间2024年12月15日,CS2上海major正在如火如荼的进行中,昨日迎来两场半决赛MOUZ对阵spirit以及FAZE对阵G2。Spirit和MOUZ和各自赢下了自己的选图之后,spirit双子星在图三抗住压力帮助队伍杀入决赛。而G2和FAZE的比赛中,FAZE依然延续上一场的火热手感完全压制了G2,G2的明星选…...
【Leetcode 每日一题】3266. K 次乘运算后的最终数组 II
问题背景 给你一个整数数组 n u m s nums nums,一个整数 k k k 和一个整数 m u l t i p l i e r multiplier multiplier。 你需要对 n u m s nums nums 执行 k k k 次操作,每次操作中: 找到 n u m s nums nums 中的 最小 值 x x x&a…...
etcd集群常见日志
1、节点失去领导者 {"level":"info","ts":"2024-05-07T01:54:04.948Z","logger":"raft","caller":"etcdserver/zap_raft.go:77","msg":"raft.node: 9afce9447872453 lost le…...
【漫话机器学习系列】005.神经网络的结构(architecture on the neural network)
神经网络(Neural Network)是一种模拟人脑神经系统的计算模型,由大量相互连接的神经元(节点)组成,广泛应用于深度学习和机器学习领域。以下是神经网络的基本结构及关键组成部分。 1. 神经网络的基本组成 一…...
基于 Couchbase 数据仓库元数据管理的可行性方案
在大数据体系中,元数据管理是数据治理的关键一环。以下是一套元数据管理的可行性方案,适合你的当前架构设计(基于 Couchbase 数据仓库)并支持高效管理数据的分层与结构。 1. 元数据管理的目标 统一数据管理:清晰描述 …...
SpringBoot:快速构建微服务应用
一、SpringBoot简介 什么是SpringBoot 是由Pivotal团队提供的快速开发框架。它基于Spring框架,可以用于快速构建微服务应用程序。SpringBoot提供了一种快速、便捷的方式来启动和配置一个基于Spring的应用程序,它封装了很多常用的配置,简化了开…...
汽车嵌入式软件构建高效技术团队的全面思考
在汽车嵌入式软件开发领域,构建一支高效的通用技术团队至关重要。这类团队负责为各种项目提供可复用、标准化的技术基石,从而提高开发效率、降低成本并确保产品质量。构建这样的团队需要从技术能力、角色分工、标准化与复用、流程管理与质量保证、工具和…...
【跨库查询、多库查询】.NET开源 ORM 框架 SqlSugar 系列
文章目录 一、跨库方式1:跨库导航二、手动跨库查询三、同服务器:自动查询跨库查询3.1 Mysql和SqlServer自动3.2 自动: PgSql跨Scheme查询3.3 其他库同服务器 四、跨服务器:自动跨库查询4.1 配置SqlServer dblink4.2 配置 Oracle dblink4.3 配…...
智能人体安全防护:3D 视觉技术原理、系统架构与代码实现剖析
随着工业化程度的提高,生产安全已成为企业关注的重点。尤其是在一些存在禁区的工业厂区和车间,人员误入或违规进入将带来严重的安全隐患。为了解决这一问题,迈尔微视推出了智能人体安全检测解决方案,为企业提供全方位的人员安全监…...
第24周:文献阅读
目录 摘要 Abstract 一、现有问题 二、提出方法 三、创新点 模型结构创新 强化学习与GAN结合 属性特征与通顺性优化 四、方法论 生成对抗网络(GAN) 强化学习(RL) 模型组件 五、实验研究 数据集 数据预处理 评价指…...
yolov8 转华为昇腾om脚本
目录 yolov8 转华为昇腾 om脚本 测试ok 推理demo: yolov8 转华为昇腾 om脚本 测试ok import sys import osos.chdir(os.path.dirname(os.path.abspath(__file__)))import torchcurrent_dir = os.path.dirname(os.path.abspath(__file__))paths = [os.path.abspath(__file__)…...
分布式事物XA、BASE、TCC、SAGA、AT
分布式事务——Seata 一、Seata的架构: 1、什么是Seata: 它是一款分布式事务解决方案。官网查看:Seata 2.执行过程 在分布式事务中,会有一个入口方法去调用各个微服务,每一个微服务都有一个分支事务,因…...
域名信息收集(小迪网络安全笔记~
附:完整笔记目录~ ps:本人小白,笔记均在个人理解基础上整理,若有错误欢迎指正! 2.1 域名信息收集 引子:上一章介绍了服务器的信息收集。本篇则介绍在面对存在Web资产企业时,其域名信息该如何收…...
力扣-图论-13【算法学习day.63】
前言 ###我做这类文章一个重要的目的还是给正在学习的大家提供方向和记录学习过程(例如想要掌握基础用法,该刷哪些题?)我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非…...
【设计模式】如何用C++实现观察者模式【发布订阅机制】
【设计模式】如何用C实现观察者模式【发布订阅机制】 一、问题背景 代码质量影响生活质量。最近工作中频繁接触各种设计模式,深刻体会到优秀的设计模式不仅能显著降低后续维护的压力,还能提升开发效率。观察者模式作为一种降低耦合度、提高扩展性的利器…...
【LC】2717. 半有序排列
题目描述: 给你一个下标从 0 开始、长度为 n 的整数排列 nums 。 如果排列的第一个数字等于 1 且最后一个数字等于 n ,则称其为 半有序排列 。你可以执行多次下述操作,直到将 nums 变成一个 半有序排列 : 选择 nums 中相邻的两…...
AI智算-k8s部署大语言模型管理工具Ollama
文章目录 简介k8s部署OllamaOpen WebUI访问Open-WebUI 简介 Github:https://github.com/ollama/ollama 官网:https://ollama.com/ API:https://github.com/ollama/ollama/blob/main/docs/api.md Ollama 是一个基于 Go 语言开发的可以本地运…...
AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南
点一下关注吧!!!非常感谢!!持续更新!!! 🚀 AI篇持续更新中!(长期更新) 目前2025年06月05日更新到: AI炼丹日志-28 - Aud…...
YSYX学习记录(八)
C语言,练习0: 先创建一个文件夹,我用的是物理机: 安装build-essential 练习1: 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件,随机修改或删除一部分,之后…...
汽车生产虚拟实训中的技能提升与生产优化
在制造业蓬勃发展的大背景下,虚拟教学实训宛如一颗璀璨的新星,正发挥着不可或缺且日益凸显的关键作用,源源不断地为企业的稳健前行与创新发展注入磅礴强大的动力。就以汽车制造企业这一极具代表性的行业主体为例,汽车生产线上各类…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...
10-Oracle 23 ai Vector Search 概述和参数
一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI,使用客户端或是内部自己搭建集成大模型的终端,加速与大型语言模型(LLM)的结合,同时使用检索增强生成(Retrieval Augmented Generation &#…...
视频行为标注工具BehaviLabel(源码+使用介绍+Windows.Exe版本)
前言: 最近在做行为检测相关的模型,用的是时空图卷积网络(STGCN),但原有kinetic-400数据集数据质量较低,需要进行细粒度的标注,同时粗略搜了下已有开源工具基本都集中于图像分割这块,…...
C++:多态机制详解
目录 一. 多态的概念 1.静态多态(编译时多态) 二.动态多态的定义及实现 1.多态的构成条件 2.虚函数 3.虚函数的重写/覆盖 4.虚函数重写的一些其他问题 1).协变 2).析构函数的重写 5.override 和 final关键字 1&#…...
掌握 HTTP 请求:理解 cURL GET 语法
cURL 是一个强大的命令行工具,用于发送 HTTP 请求和与 Web 服务器交互。在 Web 开发和测试中,cURL 经常用于发送 GET 请求来获取服务器资源。本文将详细介绍 cURL GET 请求的语法和使用方法。 一、cURL 基本概念 cURL 是 "Client URL" 的缩写…...
Vue ③-生命周期 || 脚手架
生命周期 思考:什么时候可以发送初始化渲染请求?(越早越好) 什么时候可以开始操作dom?(至少dom得渲染出来) Vue生命周期: 一个Vue实例从 创建 到 销毁 的整个过程。 生命周期四个…...
阿里云Ubuntu 22.04 64位搭建Flask流程(亲测)
cd /home 进入home盘 安装虚拟环境: 1、安装virtualenv pip install virtualenv 2.创建新的虚拟环境: virtualenv myenv 3、激活虚拟环境(激活环境可以在当前环境下安装包) source myenv/bin/activate 此时,终端…...
