vue-cli项目配置使用unocss

news2025/1/13 16:08:49

在了解使用了Unocss后,就完全被它迷住了。接手过的所有项目都配置使用了它,包括一些旧项目,也跟同事分享了使用Unocss的便捷性。

这里分享一下旧项目如何配置和使用Unocss的,项目是vue2+vue-cli构建的,node<20平常开发这些项目都需要切换到16.x去启动。

vscode插件UnoCSS

使用前先安装vscode插件,有了它对于编写UnoCSS的样式类提供了极大的便利,真的是事半功倍。

请添加图片描述

安装依赖

官方提供了两种方式的配置,一个是作为postcss的插件@unocss/postcss;一个是作为webpack插件@unocss/webpack

本来是选择了postcss插件去安装的,但是偶尔会出现依赖安装时卡住就不动了,多个同事反映之后就改为了webpack插件的方式。目前没有发现任何问题。

ok,采用webpack插件的方式,安装依赖:

npm install -D @unocss/webpack unocss

创建unocss配置文件uno.config.ts:

可以暂时不需要考虑配置自定义的规则等,在慢慢使用过程中熟悉之后再去查看每个配置的功能作用,我们这里配置拉满。

import {
  defineConfig,
  presetAttributify,
  presetUno,
  presetIcons,
  presetTypography,
  transformerVariantGroup,
} from 'unocss';

export default defineConfig({
  rules: [
    // 这里可以自定义一些规则
  ],
  presets: [
    presetUno(),
    presetAttributify(),
    presetIcons(),
    presetTypography(),
  ],
  transformers: [transformerVariantGroup()],
});

@unocss/webpack 插件需要依赖style-loadercss-loader 为了加载.css文件。正常来说使用了vue-cli构建的项目,已经具备加载.css的能力。

配置webpack

在配置插件之前,确认一下@vue/cli-service的版本,针对不同的版本,它依赖的webpack版本也不同,就需要不同的配置,分为wepack@4webpack@5 两种情况。

可以在package-lock.json 查找@vue/cli-service依赖的webpack版本

请添加图片描述

我当前项目的@vue/cli-service@3.9.0 依赖的webpack版本是4.0。但是我们安装的是最新版的unocss@0.65,从v0.59开始仅支持ESM的加载方式,所以配置时需要动态加载。

为了避免被旧依赖安装配置的问题所缠绕,也为了使用到最新版的unocss功能。对当前项目的@vue/cli-service进行升级,升级版本到@vue/cli-service@5

升级版本不是很麻烦,我们查看开发环境所需的依赖的版本,如果太旧了删除掉重新安装,比如@vue/*开头、babeleslint等,在安装新版本时,如果出现依赖冲突可以降低一个版本安装。

折腾了一两个小时,更新之后发现代码里出现eslint规则校验问题有这么多。

推荐一个可以查看依赖版本的工具,可以 升级依赖,查看依赖关系图

请添加图片描述

升级完成之后按照当前版本配置修改vue.config.js,因为原来的vue.config.js导出的是一个配置对象,而且@vue/cli-service@3只支持对象,这使我不得不放弃直接配置unocss的想法,选择了项目升级。

module.exports = {
    // ...
}

升级后的vue-cli是支持定义函数加载的,我们修改配置如下,使用import动态加载,可以使用defineConfig

升级完成后的@vue/cli-service版本是^5.0.8,配置按照webpack 5

const { defineConfig } = require("@vue/cli-service");
// ...

module.exports = async () => {
    const { default: UnoCSS } = await import('@unocss/webpack');

    reutnr {
        chainWebpack: (config) => {
            config.module.rule('vue').uses.delete('cache-loader');
            // 使用了ts 开启
            // config.module.rule('tsx').uses.delete('cache-loader')
            config.merge({
                cache: false,
            });
            // ...other
        },
        configureWebpack: {
            plugins: [UnoCSS()],
            optimization: {
              realContentHash: true,
            },
        },
        css: {
            extract:
                process.env.NODE_ENV === 'development'
                ? {
                    filename: '[name].css',
                    chunkFilename: '[name].[hash:9].css',
                    }
                : true,
        },
    }
}

配置完插件之后,我们还需要最后一步,在主入口文件中加载import 'uno.css'css文件。在main.js中添加:

import 'uno.css';

这里就配置完成了,记得安装vscode的插件,可愉快的在代码里写样式了。

请添加图片描述

配置postcss插件

项目里配置了postcss插件postcss-px-to-viewport,本来是用@unocss/postcss是不需要再处理的,现在改为配置为webpack插件,需要处理下pxvw的问题。

基准设计图尺寸为1920px,定义转换的方法:

// unocss px转vw
const px2Vw = (width) => {
  if (Math.abs(width) < 2) {
    return width + "px";
  }
  return ((width / 1920) * 100).toFixed(5) + "vw";
};

根据参数类型定义找到了一个插件的配置项,可以在生成数据对象后进行一次处理。

{
  //... other
  /**
   * Postprocess the generate utils object
   */
  postprocess?: Arrayable<Postprocessor>
}

这里的postprocess可以是一个对象;也可以是一个数组;type Postprocessor = (util: UtilObject) => void 定义一个函数,参数是一个UtilObject对象。我们可以直接修改对象里的数据,不需要返回。

可以自己打印输出这个对象里有什么,也可以看源码类型定义。在函数中可以拿到已经生成的css样式,然后可以直接修改。

interface UtilObject {
  selector: string
  entries: CSSEntries
  parent: string | undefined
  layer: string | undefined
  sort: number | undefined
  noMerge: boolean | undefined
}

util.entries 是一个数组,它把我们定义的比如font-size-20px拆分成了['font-size','20px'],这样我们需要遍历这个数组,将值为px的属性值转换成vw

OK,到这之后我们就可以在webpackunocss插件定义postprocess来处理。

UnoCSS({
  postprocess: (util) => {
    // 匹配px值
    const pxReg = /^-?[\.\d]+px$/;

    util.entries.forEach((item) => {
      const value = item[1];
      if (value && typeof value === "string" && pxReg.test(value)) {
        // 调用方法直接赋值
        item[1] = px2Vw(value.slice(0, -2) * 1);
      }
    });
  }
}),

测试可以看到生成的css样式已经转换成vw了。

unocss的版本选择

开始升级选择了安装最新的版本,发现使用时开发环境下没有问题。线上同事打包时说报错,打包不了,心想只能是这个版本的问题了,然后直接退回到0.59版本,这个版本在其他项目里也用肯定没问题,线上部署过后。尝试了从最新版本慢慢降级,最后测试降低了两个小版本才正常。

解决类名冲突

旧项目也定义了大量的css中,unocss可能会把原项目中的class类名识别并增加了样式,这就导致之前样式出现问题,为了暂时解决这个问题,我们屏蔽掉unocss中有冲突的css类名。

修改配置 uno.config.js:

export default defineConfig({
  // ...
  blocklist: ["container", "table"],
})

通过设置blocklist白名单,排除这些类名.container.table的css生成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2276036.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

StarRocks Awards 2024 年度贡献人物

在过去一年&#xff0c;StarRocks 在 Lakehouse 与 AI 等关键领域取得了显著进步&#xff0c;其卓越的产品功能极大地简化和提升了数据分析的效率&#xff0c;使得"One Data&#xff0c;All Analytics" 的愿景变得更加触手可及。 虽然实现这一目标的道路充满挑战且漫…

[SAP ABAP] APPEND INITIAL LINE 追加空行

语法格式 APPEND INITIAL LINE TO itab.示例1 SFLIGHT(航班) 输出结果&#xff1a; 示例2 我们可以使用下面的语法进行内表分配指针&#xff0c;追加空行并赋值的操作 APPEND INITIAL LINE TO lt_tab ASSIGNING FIELD-SYMBOL(<lfs_val>). REPORT z437_test_2025.* 自…

qml SpringAnimation详解

1. 概述 SpringAnimation 是 Qt Quick 中用于模拟弹簧效果的动画类。它通过模拟物体在弹簧力作用下的反应&#xff0c;产生一种振荡的动画效果&#xff0c;常用于模拟具有自然回弹、弹性和振动的动态行为。这种动画效果在 UI 中广泛应用&#xff0c;特别是在拖动、拉伸、回弹等…

【数据结构-堆】力扣1834. 单线程 CPU

给你一个二维数组 tasks &#xff0c;用于表示 n​​​​​​ 项从 0 到 n - 1 编号的任务。其中 tasks[i] [enqueueTimei, processingTimei] 意味着第 i​​​​​​​​​​ 项任务将会于 enqueueTimei 时进入任务队列&#xff0c;需要 processingTimei 的时长完成执行。 现…

[云原生之旅] K8s-Portforward的另类用法, 立省两个端口

前言 此方法适用于Pod不需要大量连接的情况: 有多个pod在执行任务, 偶尔需要连接其中一个pod查看进度/日志;对pod执行一个脚本/命令; 不适用于大量连接建立的情况: pod启的数据库服务;pod启的Api服务;pod启的前端服务;pod启的Oss服务; Portforward简介 Portforward就是端…

MySQL表的增删改查(基础)-下篇

修改 真正在改硬盘了&#xff0c;这样的修改是“持久有效”。一定要确保&#xff0c;update的修改是改对了&#xff0c;改出问题来就麻烦。指定update的时候&#xff0c;如果当前不指定任何条件&#xff0c;就会针对所有的行都能生效&#xff01; (把整个表都给改了)。 案例 --…

Conda虚拟Python环境下安装包遇到的坑

明天下午要去参加Nvidia组织的一个开发者夏令营活动&#xff0c;按照2024 NVIDIA开发者社区夏令营环境配置指南(Win & Mac)_nvidia mac-CSDN博客提供的指引配置环境。里面建议的是用conda来配置Python虚拟环境&#xff0c;原本本机直接安装最直接&#xff0c;不过正好学习下…

【Spring】@Size 无法拦截null的原因

问题复现 在构建 Web 服务时&#xff0c;我们一般都会对一个 HTTP 请求的 Body 内容进行校验&#xff0c;例如我们来看这样一个案例及对应代码。当开发一个学籍管理系统时&#xff0c;我们会提供了一个 API 接口去添加学生的相关信息&#xff0c;其对象定义参考下面的代码&…

Sping Boot教程之五十四:Spring Boot Kafka 生产者示例

Spring Boot Kafka 生产者示例 Spring Boot 是 Java 编程语言中最流行和使用最多的框架之一。它是一个基于微服务的框架&#xff0c;使用 Spring Boot 制作生产就绪的应用程序只需很少的时间。Spring Boot 可以轻松创建独立的、生产级的基于 Spring 的应用程序&#xff0c;您可…

FairGuard游戏安全2024年度报告

导 读&#xff1a;2024年&#xff0c;国内游戏市场实际销售收入3257.83亿元&#xff0c;同比增长7.53%&#xff0c;游戏用户规模6.74亿人&#xff0c;同比增长0.94%&#xff0c;市场收入与用户规模双双实现突破&#xff0c;迎来了历史新高点。但游戏黑灰产规模也在迅速扩大&…

NVIDIA Clara平台助力医学影像处理:编程案例与实践探索(上)

一、引言 1.1 研究背景与意义 在现代医学领域,医学影像技术已然成为疾病诊断、治疗方案制定以及疗效评估的关键支柱。从早期的 X 射线成像,到如今的计算机断层扫描(CT)、磁共振成像(MRI)、正电子发射断层扫描(PET)等先进技术,医学影像为医生提供了直观、精准的人体内…

influxdb 采集node_exporter数据

一、打开Scrapers添加 node_exporter地址&#xff1a;http://192.168.31.135:9100/metrics 查看数据

卷积神经04-TensorFlow环境安装

卷积神经04-TensorFlow环境安装 文章目录 卷积神经04-TensorFlow环境安装0-核心知识脉络1-参考网址2-手动安装Tensorflow-GPU1-关于Tensorflow的官网介绍2-安装Tensorflow-GPU版本1-安装Tensorflow-GPU版本脉络2-安装Tensorflow-GPU版本细节1-Anacanda配置【Python指定版本】-当…

四、智能体强化学习——单智能体工程实践与部署

实验环境与工具模型部署性能指标与评估 搭建强化学习的实验环境、调参与分布式训练&#xff0c;以及将训练好的模型集成到生产系统中并进行监控和评估。 4.1 实验环境与工具 在实际项目中&#xff0c;构建一个稳定、可扩展的实验环境至关重要。以下是一些常用的工具和方法。…

OA项目登录

导入依赖,下面的依赖是在这次OA登录中用到的 <!--web依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.sprin…

电池预测 | 第21讲 基于Gamma伽马模型结合EM算法和粒子滤波算法参数估计的锂电池剩余寿命预测

电池预测 | 第21讲 基于Gamma伽马模型结合EM算法和粒子滤波算法参数估计的锂电池剩余寿命预测 目录 电池预测 | 第21讲 基于Gamma伽马模型结合EM算法和粒子滤波算法参数估计的锂电池剩余寿命预测预测效果基本描述程序设计参考资料 预测效果 基本描述 电池预测 | 第21讲 基于Ga…

实用操作系统学习笔记

第1章 操作系统概述 操作系统基本概念 【基础知识】 操作系统&#xff1a;控制和管理整个计算机系统的硬件和软件资源&#xff0c;合理地组织、调度计算机的工作与资源的分配&#xff0c;进而为用户和其他软件提供方便接口与环境的程序集合。操作系统是计算机系统中最基本的…

银河麒麟桌面操作系统搭建FTP服务器

一、操作环境 服务端&#xff1a;银河麒麟桌面操作系统V10 客户端&#xff1a;银河麒麟桌面操作系统V10 二、服务器配置 说明&#xff1a;以下命令均在终端执行。鼠标点击桌面右键&#xff0c;在终端中打开。 操作步骤&#xff1a; &#xff08;一&#xff09;安装vsftpd…

20250112面试鸭特训营第20天

更多特训营笔记详见个人主页【面试鸭特训营】专栏 250112 1. TCP 和 UDP 有什么区别&#xff1f; 特性TCPUDP连接方式面向连接&#xff08;需要建立连接&#xff09;无连接&#xff08;无需建立连接&#xff09;可靠性可靠的&#xff0c;提供确认、重传机制不可靠&#xff0c…

深入理解 C 语言中浮点型数据在内存中的存储

文章目录 一、浮点型数据存储格式&#xff08;IEEE 754 标准&#xff09;二、举例说明单精度浮点数存储过程三、绘图说明四、双精度浮点数存储示例&#xff08;以1.5为例&#xff09; 在 C 语言的世界里&#xff0c;数据类型丰富多样&#xff0c;而浮点型数据用于表示实数&…