在开发过程当中咱们发现如下问题: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">