【unocss】自用

unocss中文官网1

不知道简写的可以在这里查

第一步

js 复制代码
npm install -D unocss

第二步

js 复制代码
// vite.config.ts
import UnoCSS from 'unocss/vite'
import { defineConfig } from 'vite'

export default defineConfig({
  plugins: [UnoCSS()]
})
js 复制代码
// main.ts
import 'virtual:uno.css'

第三步

在原子css的默认预设中,默认单位为rem,且1rem = 4px

所以如果想要默认单位为 px,需要如下设置

js 复制代码
npm i @unocss/preset-rem-to-px -D
js 复制代码
// unocss.config.js
import { defineConfig, presetAttributify, presetUno } from 'unocss'
import presetRemToPx from '@unocss/preset-rem-to-px'

export default defineConfig({
  presets: [
    presetUno(),
    presetAttributify(),
    presetRemToPx({
      baseFontSize: 4,
    }),
  ],
})

注释:

presetAttributify 的作用是支持属性的写法。

例如,可以用下面的方式替代全部写在class=" "里的方式

html 复制代码
<button
      flex
      justify-center
      items-center
      text-14
      cursor-pointer
      select-none
      px-15
      py-8
      border-rd-4
      border-none
      box-border
      color="#9b1fb9"
      bg="#409eff"
      m-auto
      hover="bg-#67c23a"
      transition="duration-.3s"
    >
	button
</button>

第四步

可以自己加一些预设,例如下面的 rules

js 复制代码
// uno.config.ts
import { defineConfig, presetAttributify, presetUno } from "unocss";
import presetRemToPx from "@unocss/preset-rem-to-px";

export default defineConfig({
  // ...UnoCSS options
  presets: [
    presetUno(),
    presetAttributify(),
    presetRemToPx({
      baseFontSize: 4,
    }),
  ],
  rules: [
    // [/^m-([\.\d]+)$/, ([_, num]) => ({ margin: `${num}px` })],
    [/^lines-(\d+)$/, ([_, lines]) => ({
      'overflow': 'hidden',
      'text-overflow': 'ellipsis', // 文本溢出时显示省略号
      'display': '-webkit-box',
      "-webkit-box-orient": 'vertical', 
      '-webkit-line-clamp': lines, // 使用捕获组中的数字来设置行数
    })],
    [
      'p-c', // 使用时只需要写 p-c 即可应用该组样式
       {
         position: 'absolute',
         top: '50%',
         left: '50%',
         transform: `translate(-50%, -50%)`
       }
   	],
  ],
  
});

用了插件才知道,原来上面的预设也是没必要的

相关推荐
arvin_xiaoting2 小时前
OpenClaw学习总结_I_核心架构_8:SessionPruning详解
前端·chrome·学习·系统架构·ai agent·openclaw·sessionpruning
工程师老罗3 小时前
Image(图像)的用法
java·前端·javascript
swipe4 小时前
把 JavaScript 原型讲透:从 `[[Prototype]]`、`prototype` 到 `constructor` 的完整心智模型
前端·javascript·面试
问道飞鱼4 小时前
【前端知识】React 组件生命周期:从底层原理到实践场景
前端·react.js·前端框架·生命周期
CHU7290354 小时前
定制专属美丽时刻:美容预约商城小程序的贴心设计
前端·小程序
浩~~5 小时前
反射型XSS注入
前端·xss
AwesomeDevin5 小时前
AI时代,我们的任务不应沉溺于与 AI 聊天,🤔 从“对话式编程”迈向“数字软件工厂”
前端·后端·架构
harrain5 小时前
antvG2折线图和区间range标记同时绘制
前端·javascript·vue.js·antv·g2
德育处主任Pro5 小时前
从重复搭建到高效生产,RollCode的H5开发新范式
前端
蜡台6 小时前
SPA(Single Page Application) Web 应用(即单页应用)架构模式 更新
前端·架构·vue·react·spa·spa更新