[{ "resource": "/d:/repo/my_test/ts-in-vue/src/App.vue", "owner": "_generated_diagnostic_collection_name_#2", "code": "1238", "severity": 8, "message": "作为表达式调用时,无法解析类修饰器的签名。\n The runtime will invoke the decorator with 2 arguments, but the decorator expects 1.", "source": "ts", "startLineNumber": 19, "startColumn": 2, "endLineNumber": 19, "endColumn": 43 }]
时间: 2023-07-08 09:52:13 浏览: 174
根据错误信息来看,这个问题可能是由于在 Vue 组件中使用了类修饰器导致的。类修饰器是 TypeScript 中的一个特性,它可以用来修改类的行为或属性。但是在 Vue 组件中使用类修饰器可能会导致一些问题,因为 Vue 组件的底层实现并不是基于类的。
为了解决这个问题,你可以尝试以下几种方法:
1. 将类修饰器移除,改为使用常规的 Vue 组件定义方式,即通过 `export default {}` 导出组件对象的方式。
2. 如果你必须使用类修饰器,可以尝试升级 TypeScript 的版本,或者修改 TypeScript 的配置文件(`tsconfig.json`),将 `experimentalDecorators` 设置为 `true`,以支持类修饰器。
```
{
"compilerOptions": {
"experimentalDecorators": true,
// ...
},
// ...
}
```
3. 如果你使用的是 Vue 3.x 版本,可以使用基于类的组件定义方式,即通过 `@Component` 装饰器来定义组件。在这种情况下,类修饰器应该可以正常工作。
```
<script lang="ts">
import { Component, Vue } from 'vue-class-component';
@Component
export default class MyComponent extends Vue {
// ...
}
</script>
```
如果你还有其他问题,请贴出详细的代码和报错信息。
阅读全文