• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

TypeScript WeakMap.get函数代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了TypeScript中dojo-shim/WeakMap.get函数的典型用法代码示例。如果您正苦于以下问题:TypeScript get函数的具体用法?TypeScript get怎么用?TypeScript get使用的例子?那么恭喜您, 这里精选的函数代码示例或许可以为您提供帮助。



在下文中一共展示了get函数的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的TypeScript代码示例。

示例1: factory

		let registryHandle = widgets.get(app).register(id, () => {
			const promise = Promise.resolve().then(() => {
				// Always call the factory in a future turn. This harmonizes behavior regardless of whether the
				// factory is registered through this method or loaded from a definition.

				const { registryProvider, defaultStore } = app;
				interface Options {
					id: string;
					registryProvider: RegistryProvider;
					stateFrom?: StoreLike;
				}
				const options: Options = { id, registryProvider };
				if (defaultStore) {
					options.stateFrom = defaultStore;
				}
				return factory(options);
			}).then((widget) => {
				if (!destroyed) {
					instanceHandle = app._instanceRegistry.addWidget(widget, id);
				}

				return widget;
			});
			// Replace the registered factory to ensure next time this widget is needed, the same widget is returned.
			registryHandle.destroy();
			registryHandle = widgets.get(app).register(id, () => promise);
			return promise;
		});
开发者ID:datafordevelopment,项目名称:dojo-frame,代码行数:28,代码来源:createApp.ts


示例2:

					.subscribe((series) => {
						privateStateMap.get(instance).series = series;
						// invalidate() is typed as being optional, but that's just a workaround until
						// <https://github.com/dojo/compose/issues/74> is in place. Silence the strict null check
						// violation for now.
						instance.invalidate!();
					});
开发者ID:novemberborn,项目名称:dojo2-dataviz,代码行数:7,代码来源:createColumnPlotMixin.ts


示例3: Promise

		return new Promise((resolve) => {
			handlesWeakMap.get(this).forEach((handle) => {
				handle && handle.destroy && handle.destroy();
			});
			this.destroy = noop;
			this.own = destroyed;
			resolve(true);
		});
开发者ID:jdonaghue,项目名称:compose,代码行数:8,代码来源:createDestroyable.ts


示例4: function

	return function(this: any, ...args: any[]) {
		const store = this;
		const state = instanceStateMap.get(store);
		if (!state || this.source) {
			return operation.apply(store, args);
		}
		if (!state.inProgress) {
			state.inProgress = true;
			setTimeout(function() {
				processNext(state);
			});
		}
		if (returnsPromise) {
			return new Promise(function(resolve, reject) {
				state.operationQueue.push(function() {
					return operation.apply(store, args).then(function(results: any) {
						resolve(results);
					}, function(error: any) {
						reject(error);
					});
				});
			});
		}
		else {
			let pushed = false;
			let observers: Observer<any>[] = [];
			let operationObservable: Observable<any>;
			const observable = createStoreObservable(
				new Observable(function subscribe(observer: Observer<{}>) {
					if (!operationObservable) {
						observers.push(observer);
					}
					else {
						operationObservable.subscribe(observer);
					}
					if (!pushed) {
						state.operationQueue.push(function() {
							operationObservable = operation.apply(store, args);
							observers.forEach(function(observer) {
								operationObservable.subscribe(observer);
							});
							return operationObservable.toPromise();
						});
						pushed = true;
					}

					return () => observers.splice(observers.indexOf(observer), 1);
				}),
				function(updateResults: UpdateResults<{}>) {
					return updateResults.successfulData;
				}
			);
			observable.subscribe();
			return observable;
		}
	};
开发者ID:maier49,项目名称:store,代码行数:56,代码来源:createOrderedOperationMixin.ts


示例5: findRouter

export function findRouter(route: Route<Context, Parameters>): Router<Context> {
	while (route.parent) {
		route = route.parent;
	}

	const router = parentMap.get(route);
	if (!router) {
		throw new Error('Cannot generate link for route that is not in the hierarchy');
	}
	else {
		return router;
	}
}
开发者ID:jdonaghue,项目名称:routing,代码行数:13,代码来源:createRouter.ts


示例6: completeStatefulState

/**
 * Internal function to unobserve the state of a `Stateful`.  It emits a `statecomplete` event which can be
 * cancelled.
 *
 * @param stateful The `Stateful` object to unobserve
 */
function completeStatefulState(stateful: Stateful<State>): void {
	const observedState = observedStateMap.get(stateful);
	if (observedState) {
		observedState.handle.destroy();
		const statecomplete = createCancelableEvent({
			type: 'state:completed',
			target: stateful
		});
		stateful.emit(statecomplete);
		if (!statecomplete.defaultPrevented) {
			stateful.destroy();
		}
	}
}
开发者ID:jdonaghue,项目名称:compose,代码行数:20,代码来源:createStateful.ts


示例7: state

}

/**
 * A weak map that contains the stateful's state
 */
const stateWeakMap = new WeakMap<Stateful<State>, State>();

/**
 * Create an instance of a stateful object
 */
const createStateful: StatefulFactory = createEvented
	.mixin({
		className: 'Stateful',
		mixin: {
			get state(this: Stateful<State>): State {
				return stateWeakMap.get(this);
			},

			setState(this: Stateful<State>, value: State): void {
				const observedState = observedStateMap.get(this);
				if (observedState) {
					observedState.observable.patch(value, { id: observedState.id });
				}
				else {
					setStatefulState(this, value);
				}
			},

			observeState(this: Stateful<State>, id: string, observable: ObservableState<State>): Handle {
				let observedState = observedStateMap.get(this);
				if (observedState) {
开发者ID:jdonaghue,项目名称:compose,代码行数:31,代码来源:createStateful.ts


示例8: get

	fetch<U>(query: Query<T, U>): Promise<U[]>;
}

export interface StoreFactory extends ComposeFactory<Store<{}, {}, any>, StoreOptions<{}, {}>> {
	<T extends {}, O extends CrudOptions>(options?: StoreOptions<T, O>): Store<T, O, UpdateResults<T>>;
}

interface BaseStoreState<T, O, U> {
	storage: Storage<T, O>;
}

const instanceStateMap = new WeakMap<Store<{}, {}, any>, BaseStoreState<{}, {}, any>>();

const createStore: StoreFactory = compose<Store<{}, {}, any>, StoreOptions<{}, {}>>({
	get(this: Store<{}, {}, any>, ids: string[] | string): Promise<{}[]> {
		return instanceStateMap.get(this).storage.get(Array.isArray(ids) ? ids : [ ids ]);
	},

	add(this: Store<{}, {}, any>, items: {}[] | {}, options?: CrudOptions) {
		const self = this;
		const storeResultsPromise = instanceStateMap.get(self).storage
			.add(Array.isArray(items) ? items : [ items ], options);
		// TODO refactoring - repetitive logic
		return createStoreObservable(
			new Observable<UpdateResults<{}>>(function subscribe(observer: Observer<UpdateResults<{}>>) {
				storeResultsPromise
					.then(function(results) {
						observer.next(results);
						observer.complete();
					}, function(error) {
						observer.error(error);
开发者ID:maier49,项目名称:store,代码行数:31,代码来源:createStore.ts



注:本文中的dojo-shim/WeakMap.get函数示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
TypeScript WeakMap.set函数代码示例发布时间:2022-05-25
下一篇:
TypeScript Symbol.default函数代码示例发布时间:2022-05-25
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap