是否有打字稿模块解析策略,允许我在同一模块中同时进行不以斜杠开头的本地导入和从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
更多背景信息:
我有一个由两个子项目组成的项目:
-图书馆
-.app
库定义了应用程序随后使用的一些实用程序。我的构建过程首先构建"库"子项目,然后将其(编译的js与d.ts文件一起)复制到"应用程序"node_modules中的"库"子文件夹,然后编译"应用程序"。
在"图书馆"中,我有以下类:
//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 有任何非公共字段,这不会立即编译(它们是从两个不同的地方导入的,所以对于打字稿来说,这是两种不同的类型)。这就是为什么我尝试两个导入我的模块,开头没有斜杠。但也许还有其他解决方案?
我认为这应该是可能的,如果你看一下 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