Skip to Content
🎉 Univer 0.8.3 版本已发布。查看详情 →
GuidesUniver Sheets进阶使用在 JavaScript 中扩展 Univer

在 JavaScript 中扩展 Univer

💡

如果发现在部分集成了 TypeScript 支持的项目中,装饰器并没有正常工作的话(通常可能是因为 babel 相关的装饰器插件实现与 TypeScript 的不一致),也可以考虑使用这种方式来替代装饰器。

为了便于开发,Univer 使用了大量的 TypeScript 装饰器语法来声明依赖注入关系。

因此我们当然推荐你首先使用 TypeScript,但如果你不熟悉 TypeScript 或者受制于其他原因,你也可以使用 JavaScript 来扩展 Univer。当然,这并不是一件容易的事情,因为你可能需要了解 Univer 的内部机制以及如何使用 JavaScript 来实现 TypeScript 中的装饰器。

在 Univer 的文档中,最常见到的装饰器是由 @univerjs/core 提供的参数装饰器(Parameter Decorators)。这里将介绍如何在 JavaScript 中替代这种装饰器。

参数装饰器

@univerjs/core 提供了 setDependencies 方法,用于在 JavaScript 中显示地声明依赖。例如:

- import { Plugin, ICommandService, UniverInstanceType } from '@univerjs/core' + import { Plugin, ICommandService, UniverInstanceType, Injector, setDependencies } from '@univerjs/core' export class MyPlugin extends Plugin { static override type = UniverInstanceType.UNIVER_UNKNOWN static override pluginName = 'MY_PLUGIN_NAME' - constructor(@Inject(Injector) protected readonly _injector: Injector, @ICommandService private readonly _commandService: ICommandService) { + constructor(_injector, _commandService) { super() + this._injector = _injector + this._commandService = _commandService } - override onStarting(injector: Injector): void { + override onStarting(injector) { - ([[ConfigService]] as Dependency[]).forEach(d => injector.add(d)) + [[ConfigService]].forEach(d => injector.add(d)) } } + setDependencies(MyPlugin, [Injector, ICommandService])

参考 redi 文档

Last updated on