# 一、使用 alias 简化路径
使用
webpack构建过Vue项目的同学应该知道alias的作用,我们可以使用它将复杂的文件路径定义成一个变量来访问。在不使用alias的项目中,我们引入文件的时候通常会去计算被引入文件对于引入它的文件的相对路径,比如像这样
import HelloWorld from '../../../../HelloWorld.vue'
@前端进阶之旅: 代码已经复制到剪贴板
一旦相对层次结构较深,我们就很难去定位所引入文件的具体位置,其实这并不是我们应该操心的地方,完全可以交给 webpack 来进行处理。在原生的 webpack 配置中我们可以定义 alias 来解决这一问题:
const path = require('path')
const resolve = dir => {
return path.join(__dirname, dir)
}
module.exports = {
...
resolve: {
alias: {
'@': resolve('src'), // 定义 src 目录变量
_lib: resolve('src/common'), // 定义 common 目录变量,
_com: resolve('src/components'), // 定义 components 目录变量,
_img: resolve('src/images'), // 定义 images 目录变量,
_ser: resolve('src/services'), // 定义 services 目录变量,
}
},
...
}
@前端进阶之旅: 代码已经复制到剪贴板
上方我们在
webpack resolve(解析)对象下配置alias的值,将常用的一些路径赋值给了我们自定义的变量,这样我们便可以将第一个例子简化为:
import HelloWorld from '_com/HelloWorld.vue'
@前端进阶之旅: 代码已经复制到剪贴板
而在
CLI 3.x中我们无法直接操作webpack的配置文件,我们需要通过chainWebpack来进行间接修改,代码如下
/* vue.config.js */
module.exports = {
...
chainWebpack: config => {
config.resolve.alias
.set