Node.js配置别名alias的两种方法

Node.js配置别名alias的两种方法

什么是别名?

// import xxx from '../../../xxx';
import xxx from '@/xx/xx/xxx';

可以省去 ../../../xxx ,直接从配置的目录开始找文件

环境准备

  1. Node.js如果下载过慢,可以从淘宝镜像下载

第一种:webpack

使用 webpack 进行打包并且在 webpack.config.js 配置里面配置 alias

配置 webpack.config.js

const path = require('path');
const resolve = path.resolve;

module.exports = {
  entry: './src/index.js',             // 入口文件
  output: {
    filename: 'bundle.js',			   // 输出文件名
    path: resolve(__dirname, 'dist')   // 输出文件路径
  },
  resolve: {
    alias: {
      '@': resolve(__dirname, 'src')   // 别名设置
    }
  }
}

之后在目录 src 下面创建 index.jstest.js

index.js

import test from '@/test';	// 这里的 @/xxx 相当于 src/xxx
console.log(test);

test.js

export default 'test';	// 随便导出什么内容

之后控制台输入 webpack 编译之后运行 node dist/bundle.js 即可输出结果 test

第二种:module-alias

控制台输入 npm install module-aliasyarn add module-alias 安装 module-alias

然后进入 package.json 加入如下配置:

"_moduleAliases": {
  "@": "src"
}

(如果使用 TypeScript 的话,可以用 tsc 直接编译。但是清注意这里的 src 应改成打包后的目录比如 dist build 等)

之后在主入口文件头部引用 module-alias/register 如:

index.js

require('module-alias/register');
const test = require('@/test');
console.log(test);

test.js

module.exports = 'test';

之后控制台运行 node src/index.js 即可输出结果 test

IDE 路径提示设置

虽然打包运行可以通过别名,但是 IDE 并不认识

我们需要在项目根目录新建文件 jsconfig.json (使用 TypeScript 则是 tsconfig.json
compilerOptions 加入:

"baseUrl": "./src",
"paths": {
  "@/*": ["*"]
}

文件最后如下:

{
  "compilerOptions": {
    "baseUrl": "./src",
    "paths": {
      "@/*": ["*"]
    }
  }
}

总结

安装环境之后两种办法:

  1. 修改 webpack 配置以支持别名打包
  2. 使用 module-alias 库进行编译运行
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值