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

简述对css工程化的理解

一、css工程化解决了哪些问题

        1、宏观设计:css如何组织、拆分、设计模块结构

        2、编码优化:如何更好地编写css

        3、构建:如何处理css,使打包结果最优

        4、可维护性:最小化后续的变更成本

二、针对问题,如何解决

        1、使用less、scss等预处理器

        2、使用工程化插件,如PostCss

        3、webpack loader等

三、为什么要使用预处理器?预处理器的好处

        预处理器支持我们写一种类似CSS、但实际并不是CSS的语言,然后将其编译成CSS。预处理器的特性可以更好的优化css,解决css的一些问题。

        预处理器的特性:

                1、嵌套能力,可以通过嵌套直观的反应css的层级关系

                2、支持定义css变量

                3、提供计算函数

                4、允许对代码片进行extend和mixin

                5、支持循环语句使用

                6、支持将css模块化,支持复用

四、PostCss是如何工作的

        PostCss和预处理器的不同就在于,预处理器处理的是类CSS,而 PostCss 处理的就是 CSS 本身。

        PostCss可以编译尚未被浏览器广泛支持的先进的 CSS 语法,还可以自动为一些需要额外兼容的语法增加前缀。更强的是,由于 PostCss 有着强大的插件机制,支持各种各样的扩展,极大地强化了 CSS 的能力。

        PostCss的使用场景:

                1、提高css的可读性,做类似预处理器的工作

                2、帮助css适配低版本浏览器

                3、允许我们编写面向未来的css,帮助编译css next

五、webpack如何处理css

        webpack在loader的辅助下,是可以处理css的。

        webpack通过安装css-loader和style-loader处理css,css-loader的作用是导入 CSS 模块,对 CSS 代码进行编译处理,style-loader的作用是创建style标签,把 CSS 内容写入标签。

        在实际使用中,css-loader 的执行顺序一定要安排在 style-loader 的前面。因为只有完成了编译过程,才可以对 css 代码进行插入;若提前插入了未编译的代码,webpack会报错。 

http://www.lryc.cn/news/331802.html

相关文章:

  • .NET 5种线程安全集合
  • 计算机信息自查
  • 配置vite配置文件更改项目端口、使用@别名
  • 【LeetCode热题100】【链表】环形链表
  • SpringBoot整合ELK8.1.x实现日志中心教程
  • 计算机网络:数据链路层 - 封装成帧 透明传输 差错检测
  • Open3D (C++) 计算点云的特征值特征向量
  • Java | Leetcode Java题解之第8题字符串转换整数atoi
  • BL200耦合器数据采集模块
  • 基于Uni-app的体育场馆预约系统的设计与实现
  • 1.Spring Boot框架整合
  • 如何在 Debian VPS 上添加、删除和授予用户 sudo 权限
  • openlayers 入门教程(九):overlay 篇
  • 基于Python的高考志愿辅助填报系统
  • 使用CMake搭建简单的Qt程序
  • Qt + VS2017 创建一个简单的图片加载应用程序
  • Linux文件搜索工具(gnome-search-tool)
  • c++20协程详解(三)
  • LLM--提示词Propmt的概念、作用及如何设计提示词
  • 59 使用 uqrcodejs 生成二维码
  • Leetcode 3097. Shortest Subarray With OR at Least K II
  • 算法系列--递归,回溯,剪枝的综合应用(2)
  • Docker搭建LNMP环境实战(09):安装mariadb
  • 基于Python的微博舆论分析,微博评论情感分析可视化系统,附源码
  • Flutter iOS上架指南
  • 实操:driver.js 实现产品导览、亮点、上下文帮助
  • 【JavaWeb】Day29.SpringBootWeb请求响应——请求(二)
  • asf是什么格式的文件?用手机怎么打开?
  • picGo图床搭建gitee和smms(建议使用)
  • LeetCode | 数组 | 二分查找 | 35.搜索插入位置【C++】