TypeScript - Unable to create a "delete" function outside of a class
我面临的问题是,在类定义之外,我无法创建名称与关键字相同的函数。
同样的"问题"出现在其他关键字上,但
这工作:
1 2 3 4 5 6 | class WebServiceInterface { create(): void { } retrieve(): void { } update(): void { } delete(): void { } } |
请注意,我有一个名为"delete"的函数成员。
但这不起作用:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | class WebServiceInterface { create(): void { } retrieve(): void { } update(): void { } delete(): void { } } module Web { var defaultInterface = new WebServiceInterface(); export function create() { defaultInterface.create(); } export function retrieve() { defaultInterface.retrieve(); } export function update() { defaultInterface.update(); } export function delete() { defaultInterface.delete(); } } |
- 需要标识符。
- 预期的表达。
- ';'预期的。
这有什么根本原因不能/不应该被允许吗?这可能只是需要用语言实现的东西吗?还有其他方法可以实现吗?
作为参考,我在 Visual Studio 2013 中使用 TypeScript 1.4。
当你想直接从命名空间/模块导出
1 2 3 4 5 6 | export default Package; declare namespace Package { function _delete(...args: any[]): any; export { _delete as delete }; } |
这里的问题是delete是JavaScript中的保留字。
删除删除块后生成的代码是:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | var WebServiceInterface = (function () { function WebServiceInterface() { } WebServiceInterface.prototype.create = function () { }; WebServiceInterface.prototype.retrieve = function () { }; WebServiceInterface.prototype.update = function () { }; WebServiceInterface.prototype.delete = function () { }; return WebServiceInterface; })(); var Web; (function (Web) { var defaultInterface = new WebServiceInterface(); function create() { defaultInterface.create(); } Web.create = create; function retrieve() { defaultInterface.retrieve(); } Web.retrieve = retrieve; function update() { defaultInterface.update(); } Web.update = update; })(Web || (Web = {})); |
猜猜取消注释删除块时它会尝试生成什么代码?
1 2 3 4 | function delete() { defaultInterface.delete(); } Web.delete = delete; |
问题是不是有效的 JavaScript,因为 delete 是保留字。
你不能命名一个函数
你可以命名一个属性
如果您将其用作属性名称,请注意,因为我怀疑 IE8 不会喜欢这样。
我最近自己也遇到了这个问题。绕过此限制的方法是将模块声明为对象。有点恶心,但它的工作原理。
例如:
1 | declare var Web: WebServiceInterface; |
这样你就得到了一个名为 Web 的变量,上面有相关的函数。
显然,如果
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | class WebServiceInterface { create(): void { } retrieve(): void { } update(): void { } delete(): void { } doOther() // etc } interface IWebObject { create(): void; retrieve(): void; update(): void; delete(): void; specialFunction(): void; defaultInterface: WebServiceInterface; // etc } declare var Web: IWebObject; |