Webpack 中css 如何 import 使用 alias别名 相对路径

在开发过程当中咱们发现如下问题:css

JS能够用alias,css就报错

js中:
import tool from '@/utils/xxx' (能够引用)
css中:
@import '@/assets/css/reset.sass' (报错) html

分析vue

缘由是 css 文件会被用 css-loader 处理,这里 css @import 后的字符串会被 css-loader 视为绝对路径解析,由于咱们并无添加 css-loader 的 alias,因此会报找不到 @ 目录。webpack

解决web

在 Webpack 中 css import 使用 alias 相对路径的解决办法有两种;sass

一是直接为 css-loader 添加 ailas 的路径,可是在 vue-webpack 给的模板中,单独针对这个插件添加配置就显得麻烦冗余了;ui

二是在引用路径的字符串最前面添加上 ~ 符号,如 @import "~@/style/theme";Webpack 会将以 ~ 符号做为前缀的路径视做依赖模块而去解析,这样 @ 的 alias 配置就能生效了。url

总结插件

~ 视为模块解析是 webpack 作的事,不是 css-loader 作的事。htm

各种非 js 直接引用(import require)静态资源,依赖相对路径加载问题,均可以用 ~ 语法完美解决;

例如 css module 中: @import "~@/style/theme"

css 属性中: background: url("~@/assets/xxx.jpg")

html 标签中: <img src="~@/assets/xxx.jpg" alt="alias">

相关文章
相关标签/搜索