Webpack 中 CSS 路径别名 ~@ 和 @ 的区别是什么?

来源:站长联盟作者:马来西亚程序员头衔:程序员
导读:本期聚焦于小伙伴创作的《Webpack 中 CSS 路径别名 ~@ 和 @ 的区别是什么?》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Webpack 中 CSS 路径别名 ~@ 和 @ 的区别是什么?》有用,将其分享出去将是对创作者最好的鼓励。

在Webpack项目里,我们经常会配置resolve.alias来简化路径引用,其中@通常是src目录的别名,而~@和@在CSS中的表现存在差异,这和Webpack的CSS解析机制有关。

Webpack 中 CSS 路径别名 ~@ 和 @ 的区别是什么?

基础配置前提

首先我们需要在Webpack配置中定义@别名,通常指向项目的src目录,基础配置如下:

// webpack.config.js
const path = require('path');

module.exports = {
  resolve: {
    alias: {
      '@': path.resolve(__dirname, 'src')
    }
  },
  module: {
    rules: [
      {
        test: /.css$/,
        use: ['style-loader', 'css-loader']
      },
      {
        test: /.(png|jpg|gif|svg)$/,
        type: 'asset/resource'
      }
    ]
  }
};

@在CSS中的表现

在CSS的url()函数里直接使用@作为别名开头时,CSS-loader默认不会把@识别为Webpack的别名,而是会按照CSS原生的相对路径规则解析。比如我们在src/styles/index.css中写如下代码:

/* src/styles/index.css */
.normal-bg {
  /* 这里@不会被识别为Webpack别名,会去当前CSS文件所在目录找@开头的资源,大概率会报错 */
  background-image: url(@/assets/bg.png);
}

这种情况下Webpack无法正确解析路径,会提示找不到对应资源,因为CSS原生语法中没有@作为别名的规则,CSS-loader默认不会对@做特殊处理。

~@在CSS中的表现

在CSS的url()中,~符号是CSS-loader约定的特殊前缀,用来告诉CSS-loader后面的内容是Webpack的模块路径,需要交给Webpack的模块解析系统处理。因此~@的组合含义是:先通过~触发Webpack模块解析,再用@别名定位到src目录。

正确的引用方式如下:

/* src/styles/index.css */
.correct-bg {
  /* ~触发Webpack解析,@指向src目录,最终会解析为src/assets/bg.png */
  background-image: url(~@/assets/bg.png);
}

此时CSS-loader会把~@/assets/bg.png交给Webpack的resolve系统,结合我们配置的@别名,就能正确找到src/assets/bg.png资源。

两种写法的核心差异对比

写法解析规则适用场景解析结果
@/path按CSS原生相对路径解析,不触发Webpack模块解析仅适用于JS文件中的路径引用大概率路径解析失败
~@/path~触发Webpack模块解析,@作为别名参与解析适用于CSS、Less、Sass等样式文件中的路径引用正确解析为对应别名目录下的资源

特殊情况说明

如果我们修改CSS-loader的配置,开启url: { filter: (url) => url.includes('@') }之类的自定义规则,也可以让@在CSS中被识别,但这种配置会增加项目复杂度,不如直接使用~@约定更通用。

另外在JS文件中引入CSS时,我们可以直接使用@作为路径开头,因为JS的模块解析本身会走Webpack的resolve系统:

// src/main.js
// JS中可以直接用@别名
import '@/styles/index.css';

总结

~@和@的核心区别是解析触发机制不同:@是Webpack的通用别名,在JS中可以直接使用,但在CSS中不会被默认解析;~@是CSS场景下的专用写法,通过~前缀触发Webpack的模块解析流程,让@别名在样式文件中生效。实际开发中,样式文件里的资源引用建议统一使用~@开头,JS文件里的路径引用使用@开头,避免路径解析错误。

WebpackCSS_路径别名~@@resolve_alias修改时间:2026-06-17 14:18:33

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。