3

这是我的用例:

我们在 Promise 库周围有一个非常轻量级的抽象,因为我们现在出于各种原因已经对其进行了多次更改,并且我们不希望在整个应用程序中更改代码。

我想向 express.Request 实例添加一个中间件,我可以通过扩展接口轻松地做到这一点,如下所示:

declare namespace Express {
    export interface Request {
        loginP(user: any): void;
    }
}

把它单独放在一个 .d.ts 文件中,一切都很好,太棒了。

然而。这是我的麻烦;在我的抽象中,我重新导出了我们正在使用的 Promise 库的接口,以便我们可以在整个应用程序中使用它并进行良好的类型检查,而不需要到处都知道它来自哪里:

import * as bluebird from 'bluebird';

export {bluebird as PType};

这非常有效;但是,仅当 .d.ts 文件不导出或导入任何内容时,扩充接口才有效,因此当我尝试loginPreturnPType<void>时,它实际返回的类型,扩充突然停止工作:

import {PType} from '../lib/Promise';

declare namespace Express {
    export interface Request {
        loginP(user: any): PType<void>;
    }
}

(使用上面的代码,loginP在界面的任何地方都找不到该成员)。如果我删除该import {PType}行一切正常 - 除了我不能返回我需要的类型。

有任何想法吗?我正在使用带有 tsconfig 文件的 typescript 1.8.9,使用tsc -p .

4

1 回答 1

3

我认为您的问题是您正在尝试执行模块合并(只要您的代码中有导出/导入语句 - 模块变为外部)。即使它不直接支持 - 你仍然可以这样做。

下面我发布了直接从typescript 手册复制的代码作为如何执行此操作的示例:

// observable.ts stays the same
// map.ts
import { Observable } from "./observable";
declare module "./observable" {
    interface Observable<T> {
        map<U>(f: (x: T) => U): Observable<U>;
    }
}
Observable.prototype.map = function (f) {
    // ... another exercise for the reader
}


// consumer.ts
import { Observable } from "./observable";
import "./map";

let o: Observable<number>;
o.map(x => x.toFixed());

希望这可以帮助。

于 2016-04-17T11:44:37.953 回答