scss :export 中导出的变量为空

文章讲述了在项目中遇到SCSS:export导出的变量为空的问题,分析了该问题可能由mini-css-extract-plugin和vue-style-loader同时存在导致,并提供了解决方案,即在配置中移除vue-style-loader,或者针对以.module.scss命名的文件使用CSSModules。此外,还提到了Vite的css-modules文档作为参考。
摘要由CSDN通过智能技术生成

scss :export 中导出的变量为空

最近在项目中发现,在其他项目中用的挺好的组件,在目前的项目中引用样式完全不对了,经过一番查找后发现是scss :export的变量为空,导致组件的样式不对劲。
下面介绍下scss :export配置方法, 及导致这个问题的原因。

一、scss :export 方法

1.在scss中配置要导出的变量


/* config.scss */

$brandPrimary: #E93030 ; //主题色/选中文字/强调文字(高亮色)/图标用色
:export {
  brandPrimary: $brandPrimary;
}

2.在vue文件导入变量并使用

import configScss from '@/style/config.scss';

export default {
    data() {
        return {
             styleObj: configScss , // 使用scss的:export的变量{brandPrimary:  #E93030}
        };
},

<style lang="scss" scoped>
/* 引入变量样式文件 */
@import "~@/styles/config.scss";
h1{
    color: $brandPrimary;
}
</style>


二、导致:export变量为{} 的原因及解决方法

理论上按照上述写法就行了,但是经测试style中进行@import样式是生效的$brandPrimary变量值也是正常传递,但是在js中styleObj.brandPrimary始终undefine。

1.导致问题原因

主要原因是mini-css-extract-plugin和vue-style-loader同时存在时候,会出现这个问题,

2.解决方法

引入mini-css-extract-plugin 时候,需要去掉vue-style-loader,目前没有发现去掉vue-style-loader 后有什么问题

还有个 按照名称为.module.scss的可以处理的,这个是vite 打包时候有效,使用webpack 不行,具体的可以参考vite的文档css-modules:https://vitejs.cn/guide/features.html#css-modules,
希望对你有所帮助

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

妮子果酱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值