首页IT科技css utility(UnoCSS 简化 CSS 的书写,Nice!)

css utility(UnoCSS 简化 CSS 的书写,Nice!)

时间2025-06-21 00:06:11分类IT科技浏览7320
导读:CSS 样式太多,重复写 在学习 UnoCSS 之前,我提出几个问题:...

CSS 样式太多             ,重复写

在学习 UnoCSS 之前                      ,我提出几个问题:

你是否有过写完了 HTML 之后      ,跳转到 style 写 CSS 这样来回跳转的痛苦? 你是否有过不知道如何给节点取类名的痛苦(有的节点确实没啥必要取类名         ,但就是需要写 CSS)? 你是否有过管理重复              、繁杂                   、繁多的 CSS 而痛苦?

以上三个问题                      ,在你使用了 UnoCSS 之后         ,基本上可以解决掉             。使用 UnoCSS 可以更加快速地构建你的 HTML 和样式                      。这是 UnoCSS 作者对 CSS 的感想:重新构想原子化 CSS      。有兴趣可以先去读一读         。文章中有一个关键词“原子化             ”      ,使用了之后才可能对这个关键词有反应                      。

对 CSS 原子化的理解

我们写 CSS 时                      ,通常都是 类名        、id           、标签 选中之后在 style 标签里写样式             ,通常都是一大坨的 CSS         。有时候我们遇到了样式复用的情况   ,提取部分相同的样式到一个 class 中                     ,再给这些节点添加一个 class:

.common { font-size: 20px; color: white; border: 1px solid #cccccc; } .a { background: green; } .b { background: blue; } <div class="a common"></div> <div class="b common"></div>

似乎这样还不让我们满意                 ,可复用性还是太低了些,假如第三个节点要用 common class 里的 border 呢?可以这样做:

.border { border: 1px solid #cccccc; } .common { font-size: 20px; color: white; } <div class="a common border"></div> <div class="b common border"></div> <div class="c common border"></div>

可以想象                 ,样式越多                  、这样提取样式的工作也就越来越多      。像是 Bootstrap 这样的 CSS 工具库                     ,给我们做了不少这样的工作   ,可以减少很多我们写 CSS 的时间             ,直接套上类名就可以了                      。但问题是                      ,我们引入了 Bootstrap 之后      ,里面没有用到的类样式         ,也会被打包到生产环境中                      ,是不是太影响性能了呢?我们的理想是         ,不用的就不要打包      ,舍弃掉                      ,而只需要用到的             。

UnoCSS

重新构想原子化 CSS - 向你介绍 UnoCSS   。我就直接通过案例来向你展示 UnoCSS 到底给我们带来了什么好处                     。先来看看我通过 UnoCSS 写的一个 Vue 组件:

再来看看我没有用 UnoCSS 的组件的样子:

是真的丑!样式也很多重复的             ,我的 font-size 已经写了不知道多少遍了   ,border-radius 也是                     ,其他组件也有写                 ,我也想过提取公共的,但是碍于太麻烦就没搞                 。

Vite + UnoCSS

cnpm i -D unocss // vite.config.ts // unocss import Unocss from "unocss/vite"; import { presetAttributify, presetUno } from "unocss"; export default defineConfig(({ command, mode }) => { return { plugins: [ vue(), Unocss({ presets: [presetAttributify({}), presetUno()], rules: [ [/^fs-(\d+\.{0,1}\d{0,2})$/, ([, d]) => ({ "font-size": `${d}px` })], [/^leh-(\d+\.{0,1}\d{0,2})$/, ([, d]) => ({ "line-height": `${d}` })], ] }) ] }; });

UnoCSS 有一些自带的 class                 ,可以使用 https://uno.antfu.me/ 来查询                     ,没有自己想要的话   ,可以通过 rules 来自己设置一个规则             ,如上                      ,就可以使用啦!

动态生成样式

来看这张图      ,c-#878787         ,UnoCSS 区别于 Bootstrap 的一个最直观的特点就是                      ,值是可以动态设置的         ,而不是静态的      ,不需要给每一个颜色写一个 class:

上面的                      ,oy           、leh 等等都是如此             ,如上   ,leh 是我自己添加的一个 rules                     ,leh-1.4 生成一个样式line-height: 1.4                 ,leh-2就可以生成:line-height: 2。

原子化:组装 CSS

其实我更想说,原子化 CSS ≈ 独立 CSS                 ,通过 class 来组装 CSS                 。而 UnoCSS 会根据给的值动态生成 CSS:

结束语

以上都是我自己使用 UnoCSS 的感想                     。UnoCSS 真的给我省了不少的功夫去写 CSS   。解决了每一次要给节点命名的痛苦!!!

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
不满足windows11最低(最新:如何在不满足最低硬件要求的电脑上升到win11系统)