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

CSS系列(18)-- 工程化实践详解

前端技术探索系列:CSS 工程化实践详解 🏗️

致读者:探索 CSS 工程化之路 👋

前端开发者们,

今天我们将深入探讨 CSS 工程化实践,学习如何在大型项目中管理 CSS。

工程化配置 🚀

项目结构

src/├── styles/│   ├── base/│   │   ├── _reset.scss│   │   ├── _typography.scss│   │   └── _variables.scss│   ├── components/│   │   ├── _button.scss│   │   ├── _card.scss│   │   └── _form.scss│   ├── layouts/│   │   ├── _grid.scss│   │   ├── _header.scss│   │   └── _footer.scss│   ├── utils/│   │   ├── _mixins.scss│   │   └── _functions.scss│   └── main.scss

构建配置

// webpack.config.js
module.exports = {module: {rules: [{test: /\.scss$/,use: [MiniCssExtractPlugin.loader,{loader: 'css-loader',options: {modules: true,importLoaders: 2}},'postcss-loader','sass-loader']}]},plugins: [new MiniCssExtractPlugin({filename: '[name].[contenthash].css'}),new PurgeCSSPlugin({paths: glob.sync(`${PATHS.src}/**/*`, { nodir: true })})]
};

模块化管理 🎯

CSS Modules

// Button.module.scss
.button {padding: 0.5em 1em;border-radius: 4px;&.primary {background: var(--primary-color);color: white;}&.secondary {background: var(--secondary-color);color: white;}
}// 使用
import styles from './Button.module.scss';const Button = () => (<button className={styles.button}>Click me</button>
);

样式组织

// _variables.scss
:root {// 颜色系统--primary-color: #007bff;--secondary-color: #6c757d;--success-color: #28a745;// 间距系统--spacing-unit: 8px;--spacing-small: calc(var(--spacing-unit) * 1);--spacing-medium: calc(var(--spacing-unit) * 2);--spacing-large: calc(var(--spacing-unit) * 3);// 字体系统--font-family-base: system-ui, -apple-system, sans-serif;--font-size-base: 16px;--line-height-base: 1.5;
}// _mixins.scss
@mixin responsive($breakpoint) {@if $breakpoint == tablet {@media (min-width: 768px) { @content; }} @else if $breakpoint == desktop {@media (min-width: 1024px) { @content; }}
}@mixin flex-center {display: flex;justify-content: center;align-items: center;
}

质量控制 💫

Stylelint 配置

// .stylelintrc.js
module.exports = {extends: ['stylelint-config-standard','stylelint-config-prettier'],plugins: ['stylelint-scss','stylelint-order'],rules: {'order/properties-alphabetical-order': true,'at-rule-no-unknown': null,'scss/at-rule-no-unknown': true,'selector-class-pattern': '^[a-z][a-zA-Z0-9]+$','max-nesting-depth': 3}
};

Git Hooks

// package.json
{"husky": {"hooks": {"pre-commit": "lint-staged"}},"lint-staged": {"*.scss": ["stylelint --fix","prettier --write"]}
}

工程化工具 🛠️

class CSSEngineering {constructor(options = {}) {this.options = {entry: 'src/styles',output: 'dist/css',modules: true,purge: true,...options};this.init();}init() {this.setupBuildSystem();this.setupLinting();this.setupOptimization();this.setupModules();}setupBuildSystem() {const webpack = require('webpack');const config = this.generateWebpackConfig();this.compiler = webpack(config);this.setupWatcher();}generateWebpackConfig() {return {entry: this.options.entry,output: {path: this.options.output,filename: '[name].[contenthash].css'},module: {rules: this.generateLoaderRules()},plugins: this.generatePlugins()};}setupLinting() {const stylelint = require('stylelint');// 设置 Stylelintthis.linter = stylelint.createLinter({config: require('./.stylelintrc.js')});// 设置 Git Hooksif (this.options.gitHooks) {this.setupGitHooks();}}setupOptimization() {if (this.options.purge) {this.setupPurgeCss();}this.setupMinification();this.setupCacheOptimization();}setupModules() {if (this.options.modules) {this.enableCSSModules();}this.setupDependencyManagement();}setupPurgeCss() {const PurgeCSSPlugin = require('purgecss-webpack-plugin');const glob = require('glob');this.plugins.push(new PurgeCSSPlugin({paths: glob.sync(`${this.options.entry}/**/*`)}));}setupMinification() {const CssMinimizerPlugin = require('css-minimizer-webpack-plugin');this.plugins.push(new CssMinimizerPlugin({minimizerOptions: {preset: ['default', {discardComments: { removeAll: true }}]}}));}setupDependencyManagement() {// 依赖图分析this.analyzeDependencies();// 循环依赖检测this.detectCircularDependencies();// 未使用代码检测this.detectUnusedCode();}analyzeDependencies() {const madge = require('madge');madge(this.options.entry).then(res => {console.log('依赖图:', res.obj());this.checkDependencies(res);});}detectCircularDependencies() {const madge = require('madge');madge(this.options.entry).then(res => {const circular = res.circular();if (circular.length) {console.warn('检测到循环依赖:', circular);}});}detectUnusedCode() {// 使用 PurgeCSS 检测未使用的 CSSconst PurgeCSS = require('purgecss');new PurgeCSS().purge({content: ['**/*.html', '**/*.js', '**/*.jsx'],css: [`${this.options.entry}/**/*.css`]}).then(result => {console.log('未使用的 CSS:', result);});}
}

最佳实践建议 💡

  1. 工程化流程

    • 统一构建流程
    • 自动化部署
    • 版本控制
    • 持续集成
  2. 代码组织

    • 模块化管理
    • 组件封装
    • 样式复用
    • 依赖管理
  3. 质量控制

    • 代码规范
    • 自动检查
    • 测试覆盖
    • 性能监控
  4. 优化策略

    • 代码压缩
    • 依赖优化
    • 按需加载
    • 缓存策略

写在最后 🌟

CSS 工程化是大型项目必不可少的环节,良好的工程化实践可以显著提升开发效率和代码质量。

进一步学习资源 📚

  • 工程化工具文档
  • 最佳实践指南
  • 性能优化策略
  • 案例研究分析

如果你觉得这篇文章有帮助,欢迎点赞收藏,也期待在评论区看到你的想法和建议!👇

终身学习,共同成长。

咱们下一期见

💻

相关文章:

CSS系列(18)-- 工程化实践详解

前端技术探索系列&#xff1a;CSS 工程化实践详解 &#x1f3d7;️ 致读者&#xff1a;探索 CSS 工程化之路 &#x1f44b; 前端开发者们&#xff0c; 今天我们将深入探讨 CSS 工程化实践&#xff0c;学习如何在大型项目中管理 CSS。 工程化配置 &#x1f680; 项目结构 …...

日拱一卒(18)——leetcode学习记录:二叉树中的伪回文路径

一、题目 给你一棵二叉树&#xff0c;每个节点的值为 1 到 9 。我们称二叉树中的一条路径是 「伪回文」的&#xff0c;当它满足&#xff1a;路径经过的所有节点值的排列中&#xff0c;存在一个回文序列。 请你返回从根到叶子节点的所有路径中 伪回文 路径的数目。 二、思路 …...

hive—炸裂函数explode/posexplode

1、Explode炸裂函数 将hive某列一行中复杂的 array 或 map 结构拆分成多行&#xff08;只能输入array或map&#xff09; 语法&#xff1a; select explode(字段) as 字段命名 from 表名; 举例&#xff1a; 1&#xff09;explode(array)使得结果中将array列表里的每个元素生…...

SpringBoot 新特性

优质博文&#xff1a;IT-BLOG-CN 2.1.0新特性最低支持jdk8,支持tomcat9 对响应式编程的支持&#xff0c;spring-boot-starter-webflux starter POM可以快速开始使用Spring WebFlux&#xff0c;它由嵌入式Netty服务器支持 1.5.8 2.1.0/2.7.0/3.0.0 Configuration propertie…...

鸿蒙app封装 axios post请求失败问题

这个问题是我的一个疏忽大意&#xff0c;在这里记录一下。如果有相同问题的朋友&#xff0c;可以借鉴。 当我 ohpm install ohos/axios 后&#xff0c;进行简单post请求验证&#xff0c;可以请求成功。 然后&#xff0c;我对axios 进行了封装。对axios 添加请求拦截器/添加响…...

消息队列 Kafka 架构组件及其特性

Kafka 人们通常有时会将 Kafka 中的 Topic 比作队列&#xff1b; 在 Kafka 中&#xff0c;数据是以主题&#xff08;Topic&#xff09;的形式组织的&#xff0c;每个 Topic 可以被分为多个分区&#xff08;Partition&#xff09;。每个 Partition 是一个有序的、不可变的消息…...

网络攻击与防范

目录 选填 第一章 1、三种网络模式 2、几种创建网络拓扑结构 NAT模式 VPN模式 软路由模式1 软路由模式2 3、Linux网络配置常用指令 4、常见网络服务配置 DHCP DNS Web服务与FTP服务 FTP用户隔离 第二章 DNS信息收集&#xff08;dnsenum、dnsmap&#xff09; 路…...

文献研读|基于像素语义层面图像重建的AI生成图像检测

前言&#xff1a;本篇文章主要对基于重建的AI生成图像检测的四篇相关工作进行介绍&#xff0c;分别为基于像素层面重建的检测方法 DIRE 和 Aeroblade&#xff0c;以及基于语义层面重建的检测方法 SimGIR 和 Zerofake&#xff1b;并对相应方法进行比较。 相关文章&#xff1a;论…...

【操作系统】为什么需要架构裁剪?

为什么需要架构裁剪&#xff1f; 原因 减小核心大小提高架构初始化速度降低内存占用提高系统性能移除不需要的功能&#xff0c;增加安全性 裁剪方法 初始化配置设置功能模块化移除不需要的驱动底层 一般裁剪对象&#xff08;以操作系统为例&#xff09; 文件系统的支持网…...

LSTM长短期记忆网络

LSTM&#xff08;长短期记忆网络&#xff09;数学原理 LSTM&#xff08;Long Short-Term Memory&#xff09;是一种特殊的递归神经网络&#xff08;RNN&#xff09;&#xff0c;解决了标准RNN中存在的梯度消失&#xff08;Vanishing Gradient&#xff09; 和**梯度爆炸&#x…...

基于前端技术UniApp和后端技术Node.js的电影购票系统

文章目录 摘要Abstruct第一章 绪论1.1 研究背景与意义1.2 国内外研究现状 第二章 需求分析2.1 功能需求分析2.2 非功能性需求分析 第二章系统设计3.1 系统架构设计3.1.1 总体架构3.1.2 技术选型 3.2 功能架构 第四章 系统实现4.1 用户端系统实现4.1.1 用户认证模块实现4.1.2 电…...

数据结构与算法:稀疏数组

前言 此文以整型元素的二维数组为例&#xff0c;阐述稀疏数组的思想。其他类型或许有更适合压缩算法或者其他结构的稀疏数组&#xff0c;此文暂不扩展。 稀疏数组的定义 在一个二维数据数组里&#xff0c;由于大量的元素的值为同一个值&#xff0c;比如 0或者其他已知的默认值…...

Meta重磅发布Llama 3.3 70B:开源AI模型的新里程碑

在人工智能领域&#xff0c;Meta的最新动作再次引起了全球的关注。今天&#xff0c;我们见证了Meta发布的Llama 3.3 70B模型&#xff0c;这是一个开源的人工智能模型&#xff0c;它不仅令人印象深刻&#xff0c;而且在性能上达到了一个新的高度。 一&#xff0c;技术突破&#…...

VSCode中的Black Formatter没有生效的解决办法

说明 如果正常按照配置进行的话&#xff0c;理论上是可以生效的。 "[python]": {"editor.defaultFormatter": "ms-python.black-formatter","editor.formatOnSave": true }但我在一种情况下发现不能生效&#xff0c;应为其本身的bug…...

【潜意识Java】蓝桥杯算法有关的动态规划求解背包问题

目录 背包问题简介 问题描述 输入&#xff1a; 输出&#xff1a; 动态规划解法 动态规划状态转移 代码实现 代码解释 动态规划的时间复杂度 例子解析 输出&#xff1a; 总结 作者我蓝桥杯&#xff1a;2023第十四届蓝桥杯国赛C/C大学B组一等奖&#xff0c;所以请听我…...

Odoo:免费开源ERP的AI技术赋能出海企业电子商务应用介绍

概述 伴随电子商务的持续演进&#xff0c;客户对于便利性、速度以及个性化服务的期许急剧攀升。企业务必要探寻创新之途径&#xff0c;以强化自身运营&#xff0c;并优化购物体验。达成此目标的最为行之有效的方式之一&#xff0c;便是将 AI 呼叫助手融入您的电子商务平台。我们…...

微信小程序苹果手机自带的数字键盘老是弹出收起,影响用户体验,100%解决

文章目录 1、index.wxml2、index.js3、index.wxss1、index.wxml <!--index.wxml--> <view class="container"><view class="code-input-container"><view class="code-input-boxes"><!-- <block wx:for="{{…...

sql中case when若条件重复 执行的顺序

sql case when若条件重复 执行的顺序 在 SQL 中&#xff0c;如果你在 CASE 表达式中定义了多个 WHEN 子句&#xff0c;并且这些条件有重叠&#xff0c;那么 CASE 表达式的执行顺序遵循以下规则&#xff1a; &#xff08;1&#xff09;从上到下&#xff1a;SQL 引擎会按照 CASE …...

压力测试Jmeter简介

前提条件&#xff1a;要安装JDK 若不需要了解&#xff0c;请直接定位到左侧目录的安装环节。 1.引言 在现代软件开发中&#xff0c;性能和稳定性是衡量系统质量的重要指标。为了确保应用程序在高负载情况下仍能正常运行&#xff0c;压力测试变得尤为重要。Apache JMeter 是一…...

cesium 与 threejs 对比

Cesium 和 Three.js 都是用于在 Web 浏览器中创建和渲染 3D 图形的强大 JavaScript 库&#xff0c;但它们有显著的不同之处&#xff0c;主要体现在应用领域、功能集和使用场景上。 以下是两者之间的对比&#xff1a; 1. 应用场景 Three.js: 适用于广泛的 3D 图形应用&#xff…...

论文解读:交大港大上海AI Lab开源论文 | 宇树机器人多姿态起立控制强化学习框架(二)

HoST框架核心实现方法详解 - 论文深度解读(第二部分) 《Learning Humanoid Standing-up Control across Diverse Postures》 系列文章: 论文深度解读 + 算法与代码分析(二) 作者机构: 上海AI Lab, 上海交通大学, 香港大学, 浙江大学, 香港中文大学 论文主题: 人形机器人…...

java_网络服务相关_gateway_nacos_feign区别联系

1. spring-cloud-starter-gateway 作用&#xff1a;作为微服务架构的网关&#xff0c;统一入口&#xff0c;处理所有外部请求。 核心能力&#xff1a; 路由转发&#xff08;基于路径、服务名等&#xff09;过滤器&#xff08;鉴权、限流、日志、Header 处理&#xff09;支持负…...

el-switch文字内置

el-switch文字内置 效果 vue <div style"color:#ffffff;font-size:14px;float:left;margin-bottom:5px;margin-right:5px;">自动加载</div> <el-switch v-model"value" active-color"#3E99FB" inactive-color"#DCDFE6"…...

vue3+vite项目中使用.env文件环境变量方法

vue3vite项目中使用.env文件环境变量方法 .env文件作用命名规则常用的配置项示例使用方法注意事项在vite.config.js文件中读取环境变量方法 .env文件作用 .env 文件用于定义环境变量&#xff0c;这些变量可以在项目中通过 import.meta.env 进行访问。Vite 会自动加载这些环境变…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数&#xff08;函数作为参数、返回值&#xff09; 三、匿名函数与闭包1. 匿名函数&#xff08;Lambda函…...

Python基于历史模拟方法实现投资组合风险管理的VaR与ES模型项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档&#xff09;&#xff0c;如需数据代码文档可以直接到文章最后关注获取。 1.项目背景 在金融市场日益复杂和波动加剧的背景下&#xff0c;风险管理成为金融机构和个人投资者关注的核心议题之一。VaR&…...

Go语言多线程问题

打印零与奇偶数&#xff08;leetcode 1116&#xff09; 方法1&#xff1a;使用互斥锁和条件变量 package mainimport ("fmt""sync" )type ZeroEvenOdd struct {n intzeroMutex sync.MutexevenMutex sync.MutexoddMutex sync.Mutexcurrent int…...

破解路内监管盲区:免布线低位视频桩重塑停车管理新标准

城市路内停车管理常因行道树遮挡、高位设备盲区等问题&#xff0c;导致车牌识别率低、逃费率高&#xff0c;传统模式在复杂路段束手无策。免布线低位视频桩凭借超低视角部署与智能算法&#xff0c;正成为破局关键。该设备安装于车位侧方0.5-0.7米高度&#xff0c;直接规避树枝遮…...

离线语音识别方案分析

随着人工智能技术的不断发展&#xff0c;语音识别技术也得到了广泛的应用&#xff0c;从智能家居到车载系统&#xff0c;语音识别正在改变我们与设备的交互方式。尤其是离线语音识别&#xff0c;由于其在没有网络连接的情况下仍然能提供稳定、准确的语音处理能力&#xff0c;广…...

消防一体化安全管控平台:构建消防“一张图”和APP统一管理

在城市的某个角落&#xff0c;一场突如其来的火灾打破了平静。熊熊烈火迅速蔓延&#xff0c;滚滚浓烟弥漫开来&#xff0c;周围群众的生命财产安全受到严重威胁。就在这千钧一发之际&#xff0c;消防救援队伍迅速行动&#xff0c;而豪越科技消防一体化安全管控平台构建的消防“…...