使用 Vue CLI 创建的 Vue 3 项目中配置@别名遇到了问题ERROR Invalid options in vue.config.js: “resolve“ is not allowed

使用 Vue CLI 创建的 Vue 3 项目中遇到了问题,当你尝试在 vue.config.js 文件中配置 resolve 选项时出现了错误提示。这是因为 resolve 选项并不是 Vue CLI 配置文件 vue.config.js 的一部分。

错误提示
在这里插入图片描述
这是因为在vue.config.js中配置

 resolve: {
    alias: {
      '@': path.resolve(__dirname, 'src'), // 这里将 @ 设置为 src 目录的别名
    },
  },

报错原因 这里的resolve方法在vite的搭建的项目中可以直接使用 但是在vue-CLI创建的vue3中不能直接拿过来使用

解决方法

const { defineConfig } = require('@vue/cli-service');
const path = require('path');
module.exports = defineConfig({
	transpileDependencies: true,
	lintOnSave: true,
	devServer: {
		port: 9527,
		open: true
	},
	chainWebpack: (config) => {
		config.resolve.alias
			.set('@', resolve('src')) // 设置 @ 为 src 目录的别名
			.end();
	}
});

function resolve(dir) {
	return path.join(__dirname, dir);
}

**在这个例子中,我们定义了一个 chainWebpack 函数来修改 Webpack 的配置。chainWebpack 函数接收一个 WebpackChain 对象作为参数,该对象允许我们链式地调用方法来修改 Webpack 的配置。

具体来说,我们设置了 resolve.alias.set(‘@’, resolve(‘src’)),这会告诉 Webpack 使用 @ 作为 src 目录的别名。

确保你的项目中有 path 模块,如果还没有引入,记得加上 const path = require(‘path’);。**

现在你应该能够在项目中使用 @ 别名了,例如:

// 在 main.js 中使用
import HelloWorld from '@/components/HelloWorld.vue';
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值