6

是否有打字稿模块解析策略允许我在同一个模块中同时拥有以斜杠开头的本地导入和从 node_modules 导入?

将“moduleResolution”设置为“node”时,编译器找不到我的本地模块,使用所有其他选项时,它看不到我尝试导入的 node_modules 目录中的模块。

我的文件中有以下导入:

import {Injectable} from "angular2/core";
import {Logger} from "core/logging/Logger";

“angular2/core”位于node_modules,“core/logging/Logger”是我的本地模块。

我认为这应该是可能的,如果您查看 angular 的代码,它们似乎两者都有,即。在 http.ts 模块中: https ://github.com/angular/angular/blob/master/modules/angular2/src/http/http.ts

import {Injectable} from 'angular2/core'; //this is local
import {Observable} from 'rxjs/Observable'; //this probably comes from node_modules

更多背景信息:
我有一个由两个子项目组成的项目:
- 库
- 应用程序
库定义了一些应用程序然后使用的实用程序。我的构建过程首先构建'library'子项目,然后将它(与d.ts文件一起编译的js)复制到'app's node_modules中的'library'子文件夹,然后编译'app'。

在“图书馆”中,我有以下课程:

//file project/library/jsonparser/JSONParser.ts
class JSONParser {...} 

//file project/library/services/ConfigurationService.ts
import {JSONParser} from "../jsonparser/JSONParser"
class ConfigurationService {
  constructor(parser: JSONParser){ ... }
}

在“应用程序”中:

import {JSONParser} from "library/jsonparser/JSONParser" //this comes from node_modules in 'app'
import {ConfigurationService} from "library/services/ConfigurationService" //from node_modules
class AppConfigurationService extends ConfigurationService {
  constructor(parser: JSONParser) {
    super(parser);
  }
}

只要 JSONParser 有任何非公共字段(它们是从两个不同的地方导入的,因此对于打字稿来说,它们是两种不同的类型),它就不会编译。这就是为什么我要尝试两个导入我的模块而不在开始时使用斜线。但也许还有其他解决方案?

4

1 回答 1

2

我认为这应该是可能的,如果您查看 angular 的代码,它们似乎两者都有,即。在 http.ts 模块中:https ://github.com/angular/angular/blob/master/modules/angular2/src/http/http.ts

不是微不足道的。

他们有模块分辨率classic https://github.com/angular/angular/blob/6b73d09ba1d8c227d1b297341de2218aea5d1276/modules/angular2/tsconfig.json#L12

从 'rxjs/Observable' 导入 {Observable};//这可能来自node_modules

他们有一个非平凡的构建管道,专门用于将其映射到node_modules. 请参阅:https ://github.com/angular/angular/blob/851647334040ec95d1ab2f376f6b6bb76ead0d9a/tools/broccoli/broccoli-typescript.ts#L271

于 2016-01-13T22:34:43.853 回答