开发者问题收集

内部服务器错误:无法读取未定义的属性“长度”

2022-04-22
6898

出现错误

[vite] Internal server error: Cannot read property 'length' of undefined

尝试使用 vite 运行我的 vue 项目时发生此问题。

以下是错误堆栈:

Build failed with 1 error: node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:59574:34: ERROR: [plugin: vite:dep-scan] Cannot read property 'length' of undefined 2:44:29 PM [vite] Internal server error: Cannot read property 'length' of undefined at matches (/Users/pandocorp/Desktop/pando/codes/pando-app/frontend/shipper/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:59574:35) at /Users/pandocorp/Desktop/pando/codes/pando-app/frontend/shipper/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:59633:58 at Array.find () at Context.resolveId (/Users/pandocorp/Desktop/pando/codes/pando-app/frontend/shipper/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:59633:42) at Object.resolveId (/Users/pandocorp/Desktop/pando/codes/pando-app/frontend/shipper/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:36609:55) at processTicksAndRejections (internal/process/task_queues.js:95:5) at async ModuleGraph.resolveUrl (/Users/pandocorp/Desktop/pando/codes/pando-app/frontend/shipper/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:56244:26) at async ModuleGraph.getModuleByUrl (/Users/pandocorp/Desktop/pando/codes/pando-app/frontend/shipper/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:56124:23) at async doTransform (/Users/pandocorp/Desktop/pando/codes/pando-app/frontend/shipper/node_modules/vite/dist/node/chunks/dep-27bc1ab8.js:55582:20)

我的 vite.config.js

import { defineConfig } from 'vite';
import { createVuePlugin } from 'vite-plugin-vue2';

const config = require('./config');
const path = require('path');

export default defineConfig({
plugins: [createVuePlugin()],
server: {
port: 8080,
},
resolve: {
alias: [
{
'@': path.resolve(__dirname, './src'),
},
{
'@common': path.resolve(__dirname, '../common-v2'),
},
// {
// find: path.resolve(__dirname, '../static'),
// replacement: config.dev.assetsSubDirectory,
// ignore: ['.'],
// },
// {
// find: path.resolve(__dirname, '../firebase-messaging-sw.js'),
// replacement: 'firebase-messaging-sw.js',
// ignore: ['.'],
// },
],
},
build: {
chunkSizeWarningLimit: 600,
cssCodeSplit: false,
},
});
3个回答

当我遇到此错误时,将以下内容添加到 vite.config.js 似乎可以解决此问题。

resolve: {
    alias: [
        {
            find: /^~(.*)$/,
            replacement: 'node_modules/$1',
        },
    ],
},
Austin White
2022-08-03

我在使用一个全新的 Vite 项目时遇到了同样的问题。我不知道你的情况是否如此,但我在另一个项目的目录下创建了这个新项目,如下所示:

/some/path/my-project              <- "parent project"
/some/path/my-project/...          <- other project files
/some/path/my-project/node_modules
/some/path/my-project/...          <- other project files
/some/path/my-project/brand-new-vite-project <--- THIS ONE!

这种嵌套似乎会产生问题,因为我将这个全新的项目移到了其他地方,一切都按预期运行。

Paolo
2023-01-09

在完成 Amplify“入门”时遇到同样的问题(需要一个新的别名)

对我来说,解决方案是按如下方式重写配置

export default defineConfig({
  plugins: [vue()],
  resolve: {
    alias: [
      {
        "./runtimeConfig": "./runtimeConfig.browser",
        "@": fileURLToPath(new URL("./src", import.meta.url)),
      },
    ],
  },
});
MonoThreaded
2023-01-28