[英]exporting imports as a namespace with TypeScript
我的问题与这个问题大致相同: https : //github.com/Microsoft/TypeScript/issues/4529
说我有这个:
//exported imports
export {ISumanOpts, IGlobalSumanObj} from 'suman-types/dts/global';
export {ITestCaseParam} from 'suman-types/dts/test-suite';
export {IHookParam} from 'suman-types/dts/test-suite';
export {IDescribeFn} from 'suman-types/dts/describe';
export {ItFn, ITestDataObj} from 'suman-types/dts/it';
export {IBeforeFn} from 'suman-types/dts/before';
export {IBeforeEachFn} from 'suman-types/dts/before-each';
export {IAfterFn} from 'suman-types/dts/after';
export {IAfterEachFn} from 'suman-types/dts/after-each';
export {DefineObjectContext as IDefObjCtx} from "./test-suite-helpers/define-options-classes";
export {DefineObjectTestCase as IDefObjTestCase} from "./test-suite-helpers/define-options-classes";
export {DefineObjectAllHook as IDefObjAllHook} from "./test-suite-helpers/define-options-classes";
export {DefineObjectEachHook as IDefObjEachHook} from "./test-suite-helpers/define-options-classes";
export namespace s {
// ! I want to move all of the above exported items into a namespace here
}
有没有一种方法使用namespace
或module
将事物导出为名称空间的一部分,而不是单独导出它们?
我有这越来越近:
因此,我尝试将它们更改为import,然后将它们放在像这样的const上:
但是正如您所看到的,我的一些声明是接口,而不是类,在那种情况下,我收到错误消息“仅引用类型,但在此处用作值”。
例如,创建一个文件名s.ts
,您要在其中导出名称空间的所有内容:
export {ISumanOpts, IGlobalSumanObj} from 'suman-types/dts/global';
export {ITestCaseParam} from 'suman-types/dts/test-suite';
export {IHookParam} from 'suman-types/dts/test-suite';
export {IDescribeFn} from 'suman-types/dts/describe';
export {ItFn, ITestDataObj} from 'suman-types/dts/it';
export {IBeforeFn} from 'suman-types/dts/before';
export {IBeforeEachFn} from 'suman-types/dts/before-each';
export {IAfterFn} from 'suman-types/dts/after';
export {IAfterEachFn} from 'suman-types/dts/after-each';
export {DefineObjectContext as IDefObjCtx} from "./test-suite-helpers/define-options-classes";
export {DefineObjectTestCase as IDefObjTestCase} from "./test-suite-helpers/define-options-classes";
export {DefineObjectAllHook as IDefObjAllHook} from "./test-suite-helpers/define-options-classes";
export {DefineObjectEachHook as IDefObjEachHook} from "./test-suite-helpers/define-options-classes";
然后,您可以在模块中执行以下操作:
import * as s from './s'
export {s}
它将在名为s
的命名空间中导出类型和值。 然后,您可以使用导入它们:
import {s} from 'your-module'
const anObject: s.ISumanOpts = {...}
我的工作是这样的:
import * as Block from './block'
import * as FullNode from './full-node'
import * as ListOnChain from './list-on-chain'
import * as HashTools from './hash-tools'
import * as KeyValueStorage from './key-value-storage'
import * as SequenceStorage from './sequence-storage'
import * as SmartContract from './smart-contract'
import * as NodeBrowser from './node-browser'
import * as NetworkApi from './network-api'
import * as NetworkClientBrowserImpl from './network-client-browser-impl'
import * as NodeApi from './node-api'
import * as NodeImpl from './node-impl'
import * as NodeTransfer from './node-transfer'
import * as NodeNetworkClient from './node-network-client'
import * as WebsocketConnector from './websocket-connector'
export {
Block,
FullNode,
ListOnChain,
HashTools,
KeyValueStorage,
SequenceStorage,
SmartContract,
NodeBrowser,
NetworkApi,
NetworkClientBrowserImpl,
NodeApi,
NodeImpl,
NodeTransfer,
NodeNetworkClient,
WebsocketConnector
}
然后在另一个文件中,我可以这样导入,所有文件都将保留在自己的空间中:
import * as AllComponents from 'blockchain-js-core'
如果要一个一个地导入它们,可以执行以下操作:
import {
Block,
FullNode,
ListOnChain,
HashTools,
KeyValueStorage,
SequenceStorage,
SmartContract,
NodeBrowser,
NetworkApi,
NetworkClientBrowserImpl,
NodeApi,
NodeImpl,
NodeTransfer,
NodeNetworkClient,
WebsocketConnector
} from 'blockchain-js-core'
一个例子可以在这里找到: https : //github.com/ltearno/blockchain-js/blob/master/blockchain-js-core/src/index.ts
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.