使用 Unocss
安装依赖
bash
pnpm add -D unocss @unocss/preset-uno unocss-applet @unocss/preset-legacy-compat
pnpm add @uni-helper/unocss-preset-uni
根目录新建文件 uno.config.js
js
/**
* @Author: jsopy
* @Date: 2024-09-16 17:01:42
* @LastEditTime: 2024-09-16 17:01:45
* @FilePath: /uniapp-uniappvue3-demo1/uno.config.js
* @Description:
* @
*/
// uno.config.js
import {
Preset,
defineConfig,
presetAttributify,
presetIcons,
transformerDirectives,
transformerVariantGroup,
} from "unocss";
import {
presetApplet,
presetRemRpx,
transformerApplet,
transformerAttributify,
} from "unocss-applet";
import { presetUni } from "@uni-helper/unocss-preset-uni";
// @see https://unocss.dev/presets/legacy-compat
import presetLegacyCompat from "@unocss/preset-legacy-compat";
const isH5 = process.env?.UNI_PLATFORM === "h5";
const isMp = process.env?.UNI_PLATFORM?.startsWith("mp") ?? false;
const presets = [];
if (!isMp) {
/**
* you can add `presetAttributify()` here to enable unocss attributify mode prompt
* although preset is not working for applet, but will generate useless css
* 为了不生产无用的css,要过滤掉 applet
*/
// 支持css class属性化,eg: `<button bg="blue-400 hover:blue-500 dark:blue-500 dark:hover:blue-600" text="sm white">attributify Button</button>`
presets.push(presetAttributify());
}
if (!isH5) {
presets.push(presetRemRpx());
}
export default defineConfig({
presets: [
presetApplet({ enable: !isH5 }),
...presets,
// 支持图标,需要搭配图标库,eg: @iconify-json/carbon, 使用 `<button class="i-carbon-sun dark:i-carbon-moon" />`
presetIcons({
scale: 1.2,
warn: true,
extraProperties: {
display: "inline-block",
"vertical-align": "middle",
},
}),
// 将颜色函数 (rgb()和hsl()) 从空格分隔转换为逗号分隔,更好的兼容性app端,example:
// `rgb(255 0 0)` -> `rgb(255, 0, 0)`
// `rgba(255 0 0 / 0.5)` -> `rgba(255, 0, 0, 0.5)`
presetLegacyCompat({
commaStyleColorFunction: true,
}),
],
/**
* 自定义快捷语句
* @see https://github.com/unocss/unocss#shortcuts
*/
shortcuts: [["center", "flex justify-center items-center"]],
transformers: [
// 启用 @apply 功能
transformerDirectives(),
// 启用 () 分组功能
// 支持css class组合,eg: `<div class="hover:(bg-gray-400 font-medium) font-(light mono)">测试 unocss</div>`
transformerVariantGroup(),
// Don't change the following order
transformerAttributify({
// 解决与第三方框架样式冲突问题
prefixedOnly: true,
prefix: "fg",
}),
transformerApplet(),
],
rules: [
[
"p-safe",
{
padding:
"env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)",
},
],
["pt-safe", { "padding-top": "env(safe-area-inset-top)" }],
["pb-safe", { "padding-bottom": "env(safe-area-inset-bottom)" }],
],
});
在 main.js 中引入
js
import "virtual:uno.css";
vite.config.js 中引入
js
import { defineConfig } from "vite";
import AutoImport from "unplugin-auto-import/vite";
import uni from "@dcloudio/vite-plugin-uni";
// https://vitejs.dev/config/
export default async () => {
const UnoCSS = (await import("unocss/vite")).default;
return defineConfig({
plugins: [
uni(),
UnoCSS(),
AutoImport({
imports: ["vue", "uni-app", "pinia"],
dts: true,
eslintrc: { enabled: true },
}),
],
});
};
在页面中使用
html
<template>
<view
class="w200rpx h100rpx bg-red-500 text-center text-white text-center line-height-100rpx"
>
自定义按钮
</view>
</template>
<script setup></script>
<style scoped></style>