useDataSourceScope
将 DataSourceCollection 的增删操作范围化,并在组件卸载时自动移除创建的数据源。
WARNING
这是一个底层辅助函数,主要供 useDataSource 使用。除非你需要自定义集合管理逻辑,否则优先使用 useDataSource。
Usage
ts
import { CustomDataSource } from 'cesium';
import { useDataSourceScope } from 'vesium';
const { add, remove } = useDataSourceScope({
destroyOnRemove: true,
});
const dataSource = add(new CustomDataSource('demo'));
// 也支持异步创建
add(Promise.resolve(new CustomDataSource('async-demo')));说明
- 目标集合默认使用
useViewer().value.dataSources。 destroyOnRemove会透传给dataSources.remove(dataSource, destroyOnRemove)。add支持 Promise,会在解析后自动加入集合。
Type Definitions
typescript
import type { CesiumDataSource } from '@vesium/shared';
import type { DataSourceCollection } from 'cesium';
import type { MaybeRefOrGetter } from 'vue';
export interface UseDataSourceScopeOptions {
/**
* The collection of DataSource to be added
* @default useViewer().value.dataSources
*/
collection?: MaybeRefOrGetter<DataSourceCollection | undefined>;
/**
* The second parameter passed to the `remove` function
*
* `dataSources.remove(dataSource,destroyOnRemove)`
*/
destroyOnRemove?: boolean;
}
/**
* Scope the SideEffects of `DataSourceCollection` operations and automatically remove them when unmounted
*/
export declare function useDataSourceScope(options?: UseDataSourceScopeOptions): import("..").UseCollectionScopeReturn<CesiumDataSource, any[], any[], any>;
//# sourceMappingURL=index.d.ts.map