TypeScript ハンドブックでは、宣言のマージの例を次に示します。
// observable.js
export class Observable<T> {
// ... implementation left as an exercise for the reader ...
}
// 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());
Webpack は TypeScript コードをコンパイルするため、次の型定義が付属する npm モジュールxstreamを使用できます。
import {Stream, MemoryStream, Listener, Producer, Operator} from './core';
export {Stream, MemoryStream, Listener, Producer, Operator};
export default Stream;
このように使用できます(map
有効な方法です):
// consumer.ts
import { Stream } from "xstream";
let s: Stream<number>;
s.map(x => x);
インターフェースを拡張したいと思いStream
、公式の例に似たものを試しました。したがって、私の場合は"xstream"
代わりに"./observable"
あり、拡張子はmap.tsではなくextensions.tsファイルにあります。
// extensions.ts
import { Stream } from "xstream";
declare module "xstream" {
interface Stream<T> {
foo(): Stream<T>;
}
}
Stream.prototype.foo = function foo() {
console.log('foo');
return this;
};
// consumer.ts
import { Stream } from "xstream";
import "./extensions";
let s: Stream<number>;
s.foo().map(x => x);
悲しいことに、複数のエラーが発生します。
ERROR in [default] <path to my project>/node_modules/xstream/index.d.ts:2:9
Export declaration conflicts with exported declaration of 'Stream'
ERROR in [default] <path to my project>/src/extendingExistingModule/extensions.ts:8:0
Cannot find name 'Stream'.
ERROR in [default] <path to my project>/src/extendingExistingModule/index.ts:5:8
Property 'map' does not exist on type 'Stream<number>'.
どうすれば修正できますか?
使用バージョン
typescript@2.0.0
xstream@5.3.2