🪲正在开发后台管理系统的同学 UnoCSS 一定要用起来

🍃你是否在为一个组件的样式就占了整个组件的 30% 甚至更多的代码而烦恼吗?今天的目的就只有一个,从编写样式上,怎么让后台管理系统的组件变得优雅。


官方文档: unocss.nodejs.cn

使用步骤 UnoCSS

1. 安装: pnpm add -D unocss

2. 配置:vite.config.ts 文件中配置如下

typescript 复制代码
import UnoCSS from 'unocss/vite'
import { defineConfig } from 'vite'

export default defineConfig({
  plugins: [
    UnoCSS(),
  ],
})

3. 创建 uno.config.ts 文件

typescript 复制代码
import { defineConfig } from 'unocss'

export default defineConfig({
  // ...UnoCSS options
})

4. 将 virtual:uno.css 添加到你的主入口中

typescript 复制代码
// main.ts
import 'virtual:uno.css'

看到这里肯定有同学会问,CSS 预处理器 SassSCSSLessStylus 已经让我们极大方便编写 CSS 样式了,怎么还要介绍这个工具?我们看下面的简单对比就能知道它的魅力了,实际开发中我们一般选一个 CSS 预处理器加上 UnoCSS 工具更高效。

编写对比


传统编写方式

typescript 复制代码
<template>
  <table class="data-table">
   <thead>
      <tr>
        <th>标题</th>
        <!-- 更多表头 -->
      </tr>
    </thead>
  </table>
</template>

<style scoped>
.data-table {
  border: 1px solid #e5e7eb;
  border-collapse: collapse;
  width: 100%;
}

.data-table th {
  background-color: #f3f4f6;
  padding: 12px 16px;
  text-align: left;
}

/* 更多样式... */
</style>

UnoCSS 编写方式

typescript 复制代码
<template>
  <table 
       border="1" 
       class="border-gray-200 w-full collapse"
    >
    <thead>
      <tr>
        <th class="bg-gray-100 p-3 text-left">标题</th>
        <!-- 更多表头 -->
      </tr>
    </thead>
  </table>
</template>

实现相同样式的目的,代码可读性上却有着不同的表现,UnoCSS 让编写样式上大大减少了维护成本。

我觉得唯一的缺点是,在没接触 UnoCSS 之前,需要花点时间熟悉它的语法🤣

相关推荐
90后小陈老师28 分钟前
3D个人简历网站 5.天空、鸟、飞机
前端·javascript·3d
不爱吃糖的程序媛4 小时前
浅谈前端架构设计与工程化
前端·前端架构设计
郝YH是人间理想6 小时前
系统架构设计师案例分析题——web篇
前端·软件工程
Evaporator Core6 小时前
深入探索:Core Web Vitals 进阶优化与新兴指标
前端·windows
初遇你时动了情6 小时前
html js 原生实现web组件、web公共组件、template模版插槽
前端·javascript·html
QQ2740287567 小时前
Soundness Gitpod 部署教程
linux·运维·服务器·前端·chrome·web3
前端小崔7 小时前
从零开始学习three.js(18):一文详解three.js中的着色器Shader
前端·javascript·学习·3d·webgl·数据可视化·着色器
哎呦你好7 小时前
HTML 表格与div深度解析区别及常见误区
前端·html
运维@小兵7 小时前
vue配置子路由,实现点击左侧菜单,内容区域显示不同的内容
前端·javascript·vue.js
koiy.cc8 小时前
记录:echarts实现tooltip的某个数据常显和恢复
前端·echarts