当前位置: 首页 > news >正文

vite配置scss全局变量

vite配置scss全局变量

创建单独文件variable.scss在其中定义变量

vite.config.ts中配置

import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import path from 'path'// https://vite.dev/config/
export default defineConfig({plugins: [vue()],resolve: {alias: {'@': path.resolve(__dirname, 'src')}},css: {preprocessorOptions: {scss: {additionalData: '@use "@/styles/variable.scss";'}}}
})

任何scss地方使用变量

p {color: variable.$color;
}

可能遇到的问题

Sass @import rules are deprecated and will be removed in Dart Sass 3.0.0

sass在3.0.0移除了@import改为@use,因此会有这个提示,所以配置时推荐使用@use

弃用的原因在于 @import 规则存在一些问题,比如会把所有变量、混入(mixins)和函数都导入到全局作用域,容易造成命名冲突,@use 规则能更好地控制作用域,避免这类问题

他们在使用时是有区别的

@import 对应使用变量

p { color: $color}

@use 对应使用变量

p {color: variable.$color; // 文件名.变量名
}

Can't find stylesheet to import. 

配置时,发现路径是对的,但是一直报错,如下

在使用相对路径的时候,vite可能无法解析,因为在sass的加载器在处理相对路径时,会根据当前文件的位置查找,而additionalData是全局注入的内容,没有明确的上下文依赖关系,因此相对路径对报错

修改为@/styles/variable.scss就可以完美解决了

Module loop: this module is already being loaded.

重复引入module报错,一般情况,如果我们在main.ts已经引入过一次scss文件,在继续在vite.config.ts中引入,报错的

修改方案: 只在一个地方引入

通常scss变量的的文件都是单独建立一个文件,不会和index.scss混在一起

index.scss通常是在main.js中引入

而variable.scss通常是在vite.config.js中配置,他们的区别是什么呢

main.js与vite.config.js 引入scss的区别

main.ts全局引入,是让整个项目都加载使用了scss文件的样式,每个scss文件的yi'ji保持了自己独立的作用域,不同文件直接的变量是不能相互使用的,这也是为什么要在vite.config.js中配置

vite.config.js的additionalData引入a文件,会保证在每个scss文件编译之前执行先编译一次a文件,保证了每次scss文件注入时,a文件变量已经都存在了,这样保证了变量可以全局使用

相关文章:

vite配置scss全局变量

vite配置scss全局变量 创建单独文件variable.scss在其中定义变量 vite.config.ts中配置 import { defineConfig } from vite import vue from vitejs/plugin-vue import path from path// https://vite.dev/config/ export default defineConfig({plugins: [vue()],resolve:…...

Spring Boot01(注解、)---java八股

Spring Boot中常用注解及其底层实现 1、SpringBootApplication注解: SpringBootApplication注解:这个注解标识了一个SpringBoot工程,它实际上是另外三个注解的组合,这三个注解是: aSpringBootConfiguration&#xff1a…...

2.19学习记录

Web easyupload3.0 这是一道构造.htaccess文件的传马 如下&#xff1a; <FilesMatch "jpg">SetHandler application/x-httpd-php </FilesMatch>.htaccess文件可以作为一个解释器&#xff0c;可以将传进去的图片马改为php马上传之后再传个图片马&#…...

汽车免拆诊断案例 | 2013 款奔驰 S300L 车起步时车身明显抖动

故障现象  一辆2013款奔驰S300L车&#xff0c;搭载272 946发动机&#xff0c;累计行驶里程约为15万km。车主反映&#xff0c;将挡位置于D挡&#xff0c;稍微释放一点制动踏板&#xff0c;车辆蠕动时车身明显抖动&#xff0c;类似气缸失火时的抖动&#xff0c;又类似手动变速器…...

【HeadFirst系列之HeadFirst设计模式】第5天之工厂模式:比萨店的秘密武器,轻松搞定对象创建!

工厂模式&#xff1a;比萨店的秘密武器&#xff0c;轻松搞定对象创建&#xff01; 大家好&#xff0c;今天我们来聊聊设计模式中的工厂模式。如果你曾经为对象的创建感到头疼&#xff0c;或者觉得代码中到处都是 new 关键字&#xff0c;那么工厂模式就是你的救星&#xff01;本…...

Redis如何解决热Key问题

目录 **如何解决 Redis 的热 Key&#xff08;Hot Key&#xff09;问题&#xff1f;****解决方案** **1. 使用多级缓存****方案** **2. 进行 Key 预分片&#xff08;Key Sharding&#xff09;****方案** **3. 使用 Redis 复制机制&#xff08;主从复制或集群&#xff09;****方案…...

从开发到部署:EasyRTC嵌入式视频通话SDK如何简化实时音视频通信的集成与应用

嵌入式设备和视频综合管理平台均支持B/S架构。在B/S架构下&#xff0c;传统的视频观看方式依赖于微软的OCX控件&#xff0c;然而OCX控件的使用正面临越来越多的挑战&#xff1a; 首先&#xff0c;用户需要安装浏览器插件、调整浏览器安全级别&#xff0c;并允许ActiveX控件弹出…...

Zookeeper(58)如何在Zookeeper中实现分布式锁?

在 Zookeeper 中实现分布式锁是一种常见的用例。Zookeeper 提供了强一致性、高可用性的分布式协调服务&#xff0c;使得它非常适合用来实现分布式锁。以下是详细的步骤和代码示例&#xff0c;展示如何在 Zookeeper 中实现分布式锁。 1. Zookeeper 分布式锁的基本原理 Zookeep…...

Mac端homebrew安装配置

拷打了一下午o3-mini-high&#xff0c;不如这位博主的超强帖子&#xff0c;10分钟结束战斗 跟随该文章即可&#xff0c;2025/2/19亲测可行 mac 安装HomeBrew(100%成功)_mac安装homebrew-CSDN博客文章浏览阅读10w次&#xff0c;点赞258次&#xff0c;收藏837次。一直觉得自己写…...

Spring 接入 DeepSeek

引入依赖 <dependency><groupId>org.springframework.ai</groupId><artifactId>spring-ai-openai-spring-boot-starter</artifactId> </dependency>2.yml配置 spring:ai:openai:api-key: sk-xxxxx // 填写自己申请的keybase-url: http…...

vscode将文件中行尾默认CRLF改为LF

安装prettier npm install --save-dev --save-exact prettier执行命令 npx prettier --write --end-of-line lf .即可将项目中的所有文件行尾序列格式改为lf *在你使用git拉取代码的时候&#xff0c;git会自动将代码当中与你当前系统不同的换行方式转化成你当前系统的换行方…...

python-leetcode 33.排序链表

题目&#xff1a; 给定链表的头结点head,请将其按升序排列&#xff0c;并返回排序后的链表 方法一&#xff1a;自顶向下归并排序 链表自顶向下归并排序的过程&#xff1a; 1.找到链表的中点&#xff0c;以中点为分界&#xff0c;将链表拆分成两个子链表。寻找链表的中点可以…...

【数据结构初阶第十二节】设计循环队列

云边有个稻草人-CSDN博客 必须有为成功付出代价的决心&#xff0c;然后想办法付出这个代价。 还有最后一道关于队列的习题&#xff0c;这题有点难&#xff0c;准备好迎接挑战吧&#xff01; 目录 1.【题目】 2.实现循环队列推荐用数组&#xff0c;Why? 3.Q1&#xff1a;如…...

基于微信小程序的民宿短租系统设计与实现(ssm论文源码调试讲解)

第4章 系统设计 4.1系统设计的目标 系统设计的目标是满足用户的需求和满足系统实现所需要的所有要求。本系统收集了信息浏览、信息删除、信息添加、信息修改、信息查询为一体[17]。改变了用户民宿短租的方式&#xff0c;提高管理员管理效率以及用户预订的效率。为用户、房主提…...

使用 Jetty 构建 HTTPS 服务入门指南

在互联网安全越来越重要的今天,使用 HTTPS 为 Web 服务提供安全传输成为标准配置。Jetty 是一个高性能、易用且功能丰富的开源 Java HTTP 服务器和 Servlet 容器,能够轻松实现 HTTPS 支持。本文将结合代码实例,引导您快速搭建一个基于 Jetty 的 HTTPS 服务。 一、Jetty 简介…...

数据结构《图》

数据结构《图论》 图的性质 一、无向图&#xff08;Undirected Graph&#xff09; 定义 由一组顶点&#xff08;Vertex&#xff09;和一组无向边&#xff08;Edge&#xff09;构成。 每条无向边用一条无方向的线段连接两个顶点&#xff0c;记为 ( (u, v) )&#xff0c;其中…...

用Chrome Recorder轻松完成自动化测试脚本录制

前言 入门自动化测试,录制回放通常是小白测试首先用到的功能。而录制回放工具也一直是各大Web自动化测试必然会着重提供的一块功能。 早期WinRunner、QTP这样的工具,自动化测试可以说是围绕录制回放开展的。近年像Selenium也提供有录制工具 Selenium IDE,Playwright也包含…...

⭐️苹果电脑安装windows10双系统【详细图文步骤保姆级教程】【本教材适用于MAC台式机、笔记本MacBook air和pro】

苹果电脑安装windows10双系统【详细图文步骤保姆级教程】【本教材适用于MAC台式机、笔记本MacBook air和pro】 苹果电脑安装windows10双系统一、准备工作准备项1&#xff1a;U盘作为系统安装盘准备项2&#xff1a;您需要安装的系统镜像 二、启动转换助理步骤1&#xff1a;找到启…...

win10系统上的虚拟机安装麒麟V10系统提示找不到操作系统

目录预览 一、问题描述二、原因分析三、解决方案四、参考链接 一、问题描述 win10系统上的虚拟机安装麒麟V10系统提示找不到操作系统&#xff0c;报错&#xff1a;Operating System not found 二、原因分析 国产系统&#xff0c;需要注意的点&#xff1a; 需要看你的系统类…...

Java 大视界 -- 开源社区对 Java 大数据发展的推动与贡献(91)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…...

物理推理与视频模型评估:计算机视觉与物理模拟的交叉应用

1. 项目概述"物理基础推理与视频模型评估"这个项目标题看似简单&#xff0c;却蕴含了计算机视觉和物理模拟两个前沿领域的交叉应用。作为一名在计算机视觉领域深耕多年的从业者&#xff0c;我最近完成了一个类似的项目&#xff0c;今天就来分享一下其中的技术细节和实…...

B站视频下载神器:3分钟解锁大会员4K画质,永久离线保存你的专属视频库

B站视频下载神器&#xff1a;3分钟解锁大会员4K画质&#xff0c;永久离线保存你的专属视频库 【免费下载链接】bilibili-downloader B站视频下载&#xff0c;支持下载大会员清晰度4K&#xff0c;持续更新中 项目地址: https://gitcode.com/gh_mirrors/bil/bilibili-downloade…...

揭秘智能音乐解锁神器:QMCDecode让QQ音乐加密格式自由播放

揭秘智能音乐解锁神器&#xff1a;QMCDecode让QQ音乐加密格式自由播放 【免费下载链接】QMCDecode QQ音乐QMC格式转换为普通格式(qmcflac转flac&#xff0c;qmc0,qmc3转mp3, mflac,mflac0等转flac)&#xff0c;仅支持macOS&#xff0c;可自动识别到QQ音乐下载目录&#xff0c;默…...

MAYA-W463-00B,融合双频Wi-Fi 6与蓝牙5.4 LE的无线模块

简介今天我要向大家介绍的是 u-blox 的无线模块——MAYA-W463-00B。它不仅支持 MU-MIMO 技术&#xff0c;还具备 Station&#xff08;站点&#xff09;、Access Point&#xff08;接入点&#xff09;以及 Wi-Fi Direct 等多种灵活的工作模式。与此同时&#xff0c;它还集成了符…...

避开这些坑!用51单片机驱动BMP280测量海拔的5个常见误区与优化技巧

避开这些坑&#xff01;用51单片机驱动BMP280测量海拔的5个常见误区与优化技巧 在嵌入式开发中&#xff0c;BMP280作为一款高精度数字气压传感器&#xff0c;常被用于海拔测量、气象监测等场景。然而&#xff0c;许多开发者在实际使用51单片机驱动BMP280时&#xff0c;往往会遇…...

为什么 Claude Code 没有一句废话?扒光它的底层提示词,我悟了!

往期热门文章&#xff1a; 1、面试官尬笑&#xff1a;你说半天就能读完一个开源项目源码&#xff0c;不就是用 AI 吗&#xff1f;我说&#xff1a;是用 DeepWiki&#xff0c;而且是 Codemap 模式&#xff01; 2、Claude Code、Cursor 和 Codex&#xff0c;到底选哪个&#xff1…...

Godot资源解包终极指南:快速提取游戏资源的完整实践教程

Godot资源解包终极指南&#xff1a;快速提取游戏资源的完整实践教程 【免费下载链接】godot-unpacker godot .pck unpacker 项目地址: https://gitcode.com/gh_mirrors/go/godot-unpacker 在Godot游戏开发与资源分析领域&#xff0c;Godot资源解包工具是一款专门用于解包…...

HelpingAI-15B:150亿参数情感对话大模型技术解析

1. 项目概述今天要和大家分享的是一个让我眼前一亮的开源项目——HelpingAI-15B。这个拥有150亿参数的大模型在情感对话领域带来了突破性的进展。作为一名长期关注对话系统发展的从业者&#xff0c;我第一时间测试了这个模型&#xff0c;发现它在理解用户情绪、提供共情回应方面…...

TM1650数显模块(下载就能用)

Keil5 TM1650.c文件#include "TM1650.h" #include "Delay.h"// (0-9) const uint8_t data_num[10] {0x3f, // 00x06, // 10x5b, // 20x4f, // 30x66, // 40x6d, // 50x7d, // 60x07, // 70x7f, // 80x6f // 9 };// ¢a-f const uint8_t data_alphab…...

基于十二要素应用的智能体驱动架构:从单体到AI原生应用演进

1. 项目概述&#xff1a;从单体应用到智能体驱动的现代应用架构最近在梳理团队内部微服务治理规范时&#xff0c;我反复思考一个问题&#xff1a;当我们将一个庞大的单体应用拆解成数十个甚至上百个独立的微服务后&#xff0c;我们是否真的获得了预期的敏捷性与可维护性&#x…...