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

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

时间2025-05-05 16:44:27分类IT科技浏览6020
导读: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
ie为什么用的人少了一些(IE为什么用的人少了?)