vue-cli项目配置使用unocss

在了解使用了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生成。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

5个不同类型的数据库安装

各种社区版本下载官方地址&#xff1a;MySQL :: MySQL Community Downloads 一、在线YUM仓库&#xff08;Linux&#xff09; 选择 MySQL Yum Repository 选择对应版本下载仓库安装包&#xff08;No thanks, just start my download.&#xff09; 下载方法1&#xff1a;下载到本…

《CPython Internals》阅读笔记:p97-p117

《CPython Internals》学习第 7 天&#xff0c;p97-p117 总结&#xff0c;总计 21 页。 一、技术总结 1.词法分析(lexical analysis) 根据《Compilers-Principles, Techniques, and Tools》(《编译原理》第2版)第 5 页&#xff1a;The first phase of a compiler is called …

js逆向说明

一 负载的内容传输用这个格式 Content-Type: multipart/form-data Content-Type 是 HTTP 请求头中的一个字段&#xff0c;它告诉服务器请求体的类型。在这个例子中&#xff0c;Content-Type 的值为 multipart/form-data&#xff0c;这表示请求体采用了 multipart/form-data 格…

什么是负载均衡?NGINX是如何实现负载均衡的?

大家好&#xff0c;我是锋哥。今天分享关于【什么是负载均衡&#xff1f;NGINX是如何实现负载均衡的&#xff1f;】面试题。希望对大家有帮助&#xff1b; 什么是负载均衡&#xff1f;NGINX是如何实现负载均衡的&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源…

spring boot学习第二十三篇:Spring Boot集成RocketMQ

前置条件先安装好RocketMQ 希望在Window10安装rocketMQ并简单使用&#xff0c;可以参考如下文章&#xff1a; Window10安装rocketMQ并简单使用-CSDN博客 1、pom.xml文件里面加上依赖 <dependency><groupId>org.apache.rocketmq</groupId><artifactId&…

OpenCV基础:视频的采集、读取与录制

从摄像头采集视频 相关接口 - VideoCapture VideoCapture 用于从视频文件、摄像头或其他视频流设备中读取视频帧。它可以捕捉来自多种源的视频。 主要参数&#xff1a; cv2.VideoCapture(source): source: 这是一个整数或字符串&#xff0c;表示视频的来源。 如果是整数&a…

使用MATLAB正则表达式从文本文件中提取数据

使用MATLAB正则表达式从文本文件中提取数据 使用Python正则表达式从文本文件中提取数据的代码请看这篇文章使用正则表达式读取文本数据【Python】-CSDN博客 文本数据格式 需要提取 V 后面的数据, 并绘制出曲线. index 1V 0.000000W 0.000000E_theta 0.000000UINV 0.0…

Table-Augmented Generation(TAG):Text2SQL与RAG的升级与超越

当下AI与数据库的融合已成为推动数据管理和分析领域发展的重要力量。传统的数据库查询方式&#xff0c;如结构化查询语言&#xff08;SQL&#xff09;&#xff0c;要求用户具备专业的数据库知识&#xff0c;这无疑限制了非专业人士对数据的访问和利用。为了打破这一壁垒&#x…

怎样使自己处于高能量状态?

在忙碌的生活中&#xff0c;保持高能量状态很关键。以下是一些简单易行的方法。 一、原谅自己&#xff0c;放下过去 别总回想让自己尴尬或犯错的事&#xff0c;这样只会消耗能量。告诉自己“错了就改&#xff0c;别再想”&#xff0c;把精力放在当下和未来。 二、避免内耗&…

Linux高并发服务器开发 第十二天(阻塞/非阻塞 fcntl函数 位图 lseek函数 传入传出参数)

目录 1.阻塞和非阻塞 2.fcntl 函数 3.位图 4.lseek 函数 5.传入参数传出参数 5.1传入参数 5.2传出参数 5.3传入传出参数 1.阻塞和非阻塞 - 阻塞、非阻塞是 设备文件、网络文件具备的属性&#xff08;不是read、write的属性&#xff09;。 - 产生阻塞的场景&#xff1…

【C语言系列】函数递归

函数递归 一、递归是什么&#xff1f;1.1尾递归 二、递归的限制条件三、递归举例3.1举例一&#xff1a;求n的阶乘3.2举例二&#xff1a;顺序打印一个整数的每一位 四、递归与迭代4.1举例三&#xff1a;求第n个斐波那契数 五、拓展学习青蛙跳台问题 一、递归是什么&#xff1f; …

啥!GitHub Copilot也免费使用了

文章目录 前言免费版直接修复代码多文件上下文Agent模式总结 前言 最近&#xff0c;GitHub 给开发者们带来了一个好消息&#xff1a;他们的 AI 编程助手 GitHub Copilot 现在可以免费使用了&#xff01;以前&#xff0c;每个月要花 10 美元才能享受的服务&#xff0c;现在对所…

【OpenGL/Assimp】渲染模型、半透明材质与封装光源

文章目录 渲染成果Assimp库准备&#xff1a;Mesh类修改&#xff1a;透明贴图使用&#xff1a;光源封装&#xff1a;使用方式在如下测试环境中&#xff1a; 渲染成果 Assimp库准备&#xff1a; 从GitHub拉取源码&#xff0c;根据网络教程&#xff0c;借助CMake生成VS工程项目&a…

【数据结构高阶】B-树

目录 一、常见的搜索结构 二、B树 2.1 B树的概念 2.2 B树插入数据的分析 2.3 B树的性能分析 2.4 模拟实现B树 2.4.1 B树节点的定义 2.4.2 B树数据的查找 2.4.3 B树节点的数据插入 2.4.4 B树的遍历 2.4.5 模拟实现B树实现的完整代码 三、B树 3.1 B树的概念 3.2 B树…

人才选拔中,如何优化面试流程

在与某大型央企的深入交流中&#xff0c;随着该企业的不断壮大与业务扩张&#xff0c;对技术人才的需求急剧上升&#xff0c;尽管企业加大了招聘力度并投入了大量资源&#xff0c;但招聘成效却不尽如人意。经过项目组细致调研与访谈&#xff0c;问题的根源逐渐浮出水面&#xf…

【Bluedroid】HFP连接流程源码分析(一)

connect /packages/modules/Bluetooth/system/btif/src/btif_hf_client.cc static bt_status_t connect(const RawAddress* bd_addr) {log::verbose("HFP Client version is {}", btif_hf_client_version);CHECK_BTHF_CLIENT_INIT(); // 检查HFP客户端是否已初始化…

Shader->LinearGradient线性渐变着色器详解

XML文件 <com.example.myapplication.MyViewxmlns:android"http://schemas.android.com/apk/res/android"android:layout_width"match_parent"android:layout_gravity"center"android:layout_height"400dp"/>自定义View代码 c…

【芯片封测学习专栏 -- 单 Die 与 多Die(Chiplet)介绍】

请阅读【嵌入式开发学习必备专栏 Cache | MMU | AMBA BUS | CoreSight | Trace32 | CoreLink | ARM GCC | CSH】 文章目录 Overview单个Die&#xff08;Monolithic Die&#xff09;多个Die&#xff08;Chiplet Architecture or Heterogeneous SoC&#xff09;如何判断一个SoC是…

acwing_5722_十滴水

acwing_5722_十滴水 下面这篇大佬的题解属实是把指针用明白了&#xff0c;可以好好理解一下&#xff1a; 原题解连接&#xff1a;AcWing 5722. 一个简单模拟实现 - AcWing map/unordered_map的用法:见收藏夹 #include<iostream> #include<unordered_map> #incl…

零基础学AI大模型要多久?真的能学会吗?

很多人都对学习AI大模型抱有疑问&#xff0c;特别是那些完全没有编程基础的朋友。其实&#xff0c;从零开始学习AI大模型是可以做到的&#xff0c;关键在于你的学习方法和投入的时间。下面我们来详细聊一聊这个问题。 学习时间 自学&#xff1a; 如果你选择自学&#xff0c;…