记录一个简单的全局引入scss(函数、变量、混合器)文件的问题

当我们直接在入口文件中引入资源文件发现,在其他scss文件中无法直接使用,还需要单独去引入一次;

为什么需要这样配置而不能在入口文件中直接引入呢?

这是因为 SCSS 的变量、函数或者混合器等内容是在编译阶段被解析的,而不是在运行时。因此,如果你想要在样式文件中使用这些内容,就需要在编译阶段将这些内容注入到每个样式文件中。
而在入口文件中引入 SCSS 文件只是将这些样式文件导入到项目中,而并不会在编译阶段将 SCSS 文件中的内容注入到每个样式文件中。
因此,如果你想要在每个样式文件中直接使用 SCSS 文件中定义的变量、函数或者混合器,就需要通过 Vite 配置项 或者webpack配置项来实现。
vite
javascript 复制代码
css: {
      //全局配置utils.scss
      preprocessorOptions: {
        scss: {
          additionalData: `@import "@/assets/style/centn/modules/util.scss";`,
        },
      },
    }
webpack
javascript 复制代码
{
      test: /\.(css|scss|sass)$/,
      use: [
        !prodMode
          ? 'style-loader'
          : {
              loader: MiniCssExtractPlugin.loader,
              options: {
                publicPath: '../'
              }
            },
        'css-loader',
        'postcss-loader',
        'sass-loader',
        {
          loader: 'sass-resources-loader',
          options: {
            resources: [
              'src/style/var.scss' 
            ]
          }
        }
      ]
    }
或者像vue-cli中
javascript 复制代码
css: {
      loaderOptions: {
        scss: {
            prependData: `@import "@/style/var.scss";`
        },
      }
    }

这意味着,你在 此配置项中引入的 SCSS 文件中定义的变量、函数或者混合器等内容都可以在项目中的任何样式文件中直接使用,而无需在每个样式文件中单独引入。

相关推荐
布列瑟农的星空13 分钟前
大话设计模式——观察者模式和发布/订阅模式的区别
前端·后端·架构
龙在天14 分钟前
Vue3 实现 B站 视差 动画
前端
KenXu15 分钟前
F2C Prompt to Design、AI 驱动的设计革命
前端
小鱼儿亮亮18 分钟前
canvas中画线条,线条效果比预期宽1像素且模糊问题分析及解决方案
前端·react.js
@大迁世界19 分钟前
用 popover=“hint“ 打造友好的 HTML 提示:一招让界面更“懂人”
开发语言·前端·javascript·css·html
伍哥的传说20 分钟前
Tailwind CSS v4 终极指南:体验 Rust 驱动的闪电般性能与现代化 CSS 工作流
前端·css·rust·tailwindcss·tailwind css v4·lightning css·utility-first
小鱼儿亮亮24 分钟前
使用Redux的combineReducers对数据拆分
前端·react.js
定栓30 分钟前
Typescript入门-类型断言讲解
前端·javascript·typescript
码间舞34 分钟前
你不知道的pnpm!如果我的电脑上安装了nvm,切换node版本后,那么pnpm还会共享一个磁盘的npm包吗?
前端·代码规范·前端工程化
用户15129054522037 分钟前
itoa函数
前端