在一个使用Vite搭建的小型Vue 3项目中,我遇到了Class constructor XX cannot be invoked without 'new'
问题。我的Google搜索表明,问题是一个转译类扩展了一个本机类,但我的代码中没有这样的结构。我对JavaScript/Typescript/transilation/ESXXXX-whatever不够熟练,无法理解它。
这里有一个最小的可行设置来演示这个问题:
npm init vue@latest
1.添加Typescript支持,保留所有其他问题为默认。cd vue-project; npm-install
1.将App.vue
的内容替换为:
<script setup lang="ts">
import { Credentials } from './creds'
function logIn( creds: Credentials ) {
// presumably log in here
}
</script>
<template>
<button @click="logIn(new Credentials( 'aaa', 'bbb' ))">CLICK ME</button>
</template>
1.添加一个新文件creds.ts
,包含以下内容:
export class Credentials {
constructor(
public readonly username: string,
public readonly password: string
) {}
toString = (): string => `${this.username}:${this.password}`;
}
npm run build; npm run preview
1.打开浏览器到127.0.0.1:4173
并打开浏览器的开发工具
1.点击按钮,检查JavaScript控制台:index.b42911a0.js:1 TypeError: Class constructor XX cannot be invoked without 'new'
两件怪事:
1.在开发(npm run dev
)中没有看到这样的错误,只有在预览生产构建时才看到。
1.如果将Credentials
类移动到App.vue
的脚本部分,则生产构建不再抛出错误。
在生产环境中,在事件处理程序中,从不同的文件示例化一个类会导致这个神秘的错误,这是怎么回事?
编辑2:我已经删除了原来的问题,因为它是所有无关紧要的。
1条答案
按热度按时间olhwl3o21#
(10/2023)我最近在Vue 3中使用组合API时遇到了这个问题。我发现,事实上,如果我们在标记中使用对象示例的赋值或类似的东西,这将导致错误。
在开发(调试)中,您将无法理解为什么不会发生这种情况,但如果您在(预览)模式下运行应用程序,则会发生这种故障。
解决方案是你必须调用一个函数,在这个函数中你可以做任何你想做的事情。
在下面的代码中,我做了一个CRUD过滤器,并借此机会在这里向大家公开它。在我调用“clear”方法的“clear”按钮上,一切正常,但是如果我单击直接在事件中分配变量的“clear”按钮,这将在生产中生成错误。