将声明设置为 TRUE 时出现打字稿错误

Typescript errors when setting declaration to TRUE

我正在尝试为我正在处理的 Angular 2 项目创建打字稿定义,以便它可以成为可导出的库。

我有几个服务设置 return 对组件的 http 请求都非常类似于以下内容:

public create(user:User) {
  return this.http.post(this._apiUrls.create,
    JSON.stringify(user), {
      headers: this.apiConfig.getApiHeaders()
    });
}

然后我从这样的组件中调用它:

Session.create(user).subscribe((res:Response) => {
  this.user = res.json().user
}); 

这一切都很好,直到我在 tsconfig 文件中将 'declaration' 设置为 true 以便我可以创建打字稿定义文件。我的一些服务开始出现以下错误:

error TS4053: Return type of public method from exported class has or is using name 'Observable' from external module "node_modules/rxjs/Observable" but cannot be named.

我大致了解问题所在,但不知道解决方案。如果我将 Observable 导入到服务中,则 typescript linter 将抛出错误,因为从技术上讲,它没有在该文件中使用。

来自 Angular 1 这是我们在所有应用程序中采用的类似范例来分解我们的代码,但也许我需要更改 Angular 2 中的方法?我看过很多其他 Angular 2 个例子,他们也都以类似的方式完成。

从今天开始,编译器不会自动在声明文件中为您导入类型。

目前最好的解决方法是手动禁用导入的 lint 规则,或者导入类型并使用显式类型注释,以便 linter 将其标记为用法。

也就是说

// Explicit import of 'Observable' so that '.d.ts' files
// can be generated correctly.
import { Observable } from "node_modules/rxjs/Observable";

// Explicit use of 'Observable' to satisfy your linter.
public create(user: User): Observable {
  return this.http.post(this._apiUrls.create,
     JSON.stringify(user), {
       headers: this.apiConfig.getApiHeaders()
    });
}