com-tools
Version:
com-tools 提供了一些通用的工具函数;
292 lines (199 loc) • 15.1 kB
TypeScript
export declare type ProxyOptions = {
get?: boolean,
set?: boolean,
configurable?: boolean,
enumerable?: boolean,
getDefault?: any,
setDefault?: any
};
/**
* 通过把值转换成JSON字符来判断是否相等
* @param value1 : any
* @param value2 : any
* @returns boolean
*
*
* 注意:
* - 方法能用于判断对象的内容是否相等,相等的条件是:这2个对象拥有相同的属性 和 属性值,且属性及属性的属性 的添加顺序是一致的;即:当两个对象的拥有相同的属性和属性值时,如果属性的定义的顺序不同,该方法会返回 false;
* - 该方法依赖于 JSON.stringify() 的逻辑;
*/
export function isEqualByJSON(value1:any, value2:any):boolean;
//遍历优化:开始
/**
* multipleLoop(option)=> stopLoop()
* 多次遍历、分批循环;可以把一个大遍历分成若干个小遍历来完成;
* @param option : {loopCall,complete,stepComplete,thisValue,total,step,delay} 选项对象
* @property option.loopCall : (index,stepCount,total)=>stopInfo : any 必选;每次循环的回调函数;入参 index : number 表示当前循环的 index,从0开始;入参 stepCount : number 表示已经遍历的批数、周期数;入参 total: number 循环的总数; 返回 stopInfo : any 停止循环并返回停止相关的信息;
* @property option.stepComplete ? : (index,stepCount,total)=>stopInfo : any 可选;每批循环完成时的回调函数;入参 index : number 表示当前循环的 index,从0开始;入参 stepCount : number 表示已经遍历的批数、周期数;入参 total: number 循环的总数; 返回 stopInfo : any 停止循环并返回停止相关的信息;
* @property option.complete ?: (stopInfo,index,stepCount,total)=>Void 可选;循环结束时的回调函数; 入参 stopInfo : any 停止循环遍历时停止信息;入参 index : number 表示最后一次循环的 index,如果值为-1 表示没有进行过循环值终止了;入参 stepCount : number 表示已经遍历的批数、周期数;入参 total: number 循环的总数;
* @property option.thisValue ? : any loopCall、complete、stepComplete 回调函数的this的值;
* @property option.total ? : number 可选;默认值:无穷大 Number.POSITIVE_INFINITY ; 设置总数循环次数;
* @property option.step ? : number 可选; 默认值: 50 ; 设置每次遍历的循环次数;
* @property option.delay ? : Timestamp 可选;默认值 :0 ; 设置再次遍历的间隔时间;
* @returns stopLoop : (stopInfo)=>Void 停止循环的函数;调用该函数,会终止正在进行的循环; 入参 stopInfo : any 停止循环的相关信息
*/
export function multipleLoop<StopInfo,ThisValue>(mLoopOpts:{
loopCall:(this:ThisValue,index:number,stepCount:number,total:number)=>StopInfo,
complete ?: (this:ThisValue,stopInfo:StopInfo,index:number,stepCount:number,total:number)=>void,
stepComplete ?: (this:ThisValue,index:number,stepCount:number,total:number)=>StopInfo,
thisValue?:ThisValue,
total?:number,
step?:number,
delay?:number
}):(stopInfo?:StopInfo)=>void;
declare global {
interface Array<T> {
/**
* multipleLoop(option)=> stopLoop()
* 多次遍历、分批循环;可以把一个大遍历分成若干个小遍历来完成;
* @param option : {loopCall,complete,stepComplete,thisValue,step,delay} 选项对象
* @property option.loopCall : (currentValue,index,stepCount,arr)=>stopInfo : any 必选;每次循环的回调函数;入参 currentValue : Item 当前index对应数组元素; 入参 index : number 表示当前循环的 index,从0开始;入参 stepCount : number 表示已经遍历的批数、周期数;入参 arr:Array 当前被循环的数组; 返回 stopInfo : any 停止循环并返回停止相关的信息;
* @property option.stepComplete ? : (index,stepCount,arr)=>stopInfo : any 可选;每批循环完成时的回调函数;入参 index : number 表示当前循环的 index,从0开始;入参 stepCount : number 表示已经遍历的批数、周期数;入参 arr: Array 被循环的数组,即当前数组; 返回 stopInfo : any 停止循环并返回停止相关的信息;
* @property option.complete ?: (stopInfo,index,stepCount,arr)=>Void 可选;循环结束时的回调函数;入参 stopInfo : any 停止循环遍历时停止信息;入参 index : number 表示最后一次循环的 index,如果值为-1 表示没有进行过循环值终止了;入参 stepCount : number 表示已经遍历的批数、周期数;入参 arr: Array 被循环的数组,即当前数组;
* @property option.thisValue ? : any 可选;默认值:当前数组; loopCall、complete、stepComplete 回调函数的this的值;
* @property option.step ? : number 可选; 默认值: 50 ; 设置每次遍历的循环次数;
* @property option.delay ? : Timestamp 可选;默认值 :0 ; 设置再次遍历的间隔时间;
* @returns stopLoop : (stopInfo)=>Void 停止循环的函数;调用该函数,会终止正在进行的循环; 入参 stopInfo : any 停止循环的相关信息
*/
multipleLoop<StopInfo,ThisValue>(mLoopOpts:{
loopCall:(this:ThisValue,index:number,stepCount:number,total:number)=>StopInfo,
complete ?: (this:ThisValue,stopInfo:StopInfo,index:number,stepCount:number,total:number)=>void,
stepComplete ?: (this:ThisValue,index:number,stepCount:number,total:number)=>StopInfo,
thisValue?:ThisValue,
step?:number,
delay?:number
}):(stopInfo?:StopInfo)=>void;
}
}
//遍历优化:结束
/**
* safelyIterate(iterable,operation, thisValue)
* 对 iterable 进行安全的迭代;与 for...of 的区别是:safelyIterate 能保证会迭代过程不会受 operation 中的行为的影响从而迭代每一个元素;
* @param iterable : Iterable 必选; 可迭代的对象;
* @param operation : (currentValue,currentIndex,iterable)=>boolean | undefined 执行的操作, 该函数的返回值表示是否要过滤出该元素
* @param thisValue ? : any 可选,默认值是 iterable ;操作 operation 的 this 值
* @returns [Item] 返回被 operation 过滤出的元素
*
*
* operation(currentValue,currentIndex,iterable)=>boolean | undefined
* @param currentValue : any 调用 operation 时的元素的值;
* @param currentIndex : number currentValue 在原始 iterable 中 对应的迭代索引值;
* @param iterable : Iterable 被迭代的 iterable ;
* @returns boolean | undefined 表示是否要过滤出 currentValue ;
*
*/
export function safelyIterate<T,ThisValue>(iterable:Iterable<T>,operation:(this:ThisValue,currentValue:T,currentIndex:number,iterable:Iterable<T>)=>any, thisValue?:ThisValue):T[];
/**
* 定义可监听的属性
*
* @param obj : Object 必选;要在其上定义属性的对象。
* @param prop : string 必选;要定义的属性的名称。
* @param options ?: {ready ?:string,noEvent ?:boolean,event ?:string,newValueKey ?:string,oldValueKey ?:string,getDefault ?:(thisValue)=>PropValue} 可选;配置选项;各个选项的说明如下;
* @property ready ?:string 可选;默认值:prop + "Ready" ;ready属性的属性名字;
* @property noEvent ?:boolean 可选;默认值:false ;是否要给 prop 属性增加值变更事件;
* @property event ?:string 可选;默认值:prop + "Change" ;prop变更事件的名字;
* @property newValueKey ?:string 可选;默认值:"value" ;prop变更事件的事件对象中保存新值的属性名字;
* @property oldValueKey ?:string 可选;默认值:"oldValue" ;prop变更事件的事件对象中保存旧值的属性名字;
* @property getDefault ?:(thisValue)=>PropValue 可选;在获取 prop 属性的值时,如果 prop 属性的值不存在 ,则会通过 该函数获取默认的值;
*
*
* @returns obj : Object 被传递给函数的对象。
*/
declare type ListenablePropOpts<T> = {
ready ?:string,
noEvent ?:boolean,
event ?:string,
newValueKey ?:string,
oldValueKey ?:string,
getDefault ?:(this:T,thisValue:T)=>any
};
export function defineListenableProperty<T extends object>(obj:T,prop:string,options?:ListenablePropOpts<T>):any;
/**
* 接口1:defineListenableProperties(obj,propsOptions)
* @param obj : Object 必选;要在其上定义属性的对象。
* @param propsOptions : {propName:options} 必选;要定义的属性的配置对象;以该配置对象的属性属性为 要配置的属性的名字,以其值为 本配置的属性的 配置选项
* @returns obj : Object 被传递给函数的对象。
*
*/
export function defineListenableProperties<T extends object>(obj:T,propsOptions:{[prop:string]:ListenablePropOpts<T>}):any;
/*
* 批量定义可监听的属性
* 接口2:defineListenableProperties(obj,propArray,options)
* @param obj : Object 必选;要在其上定义属性的对象。
* @param propArray : [string] 必选;要在其上定义的属性的名字列表。
* @param options ?: {ready ?:string,noEvent ?:boolean,event ?:string,newValueKey ?:string,oldValueKey ?:string,getDefault ?:(thisValue)=>PropValue} 可选;配置选项;各个选项的说明如下;
*
* @returns obj : Object 被传递给函数的对象。
*/
export function defineListenableProperties<T extends object>(obj:T,propArray:string[],options?:ListenablePropOpts<T>):any;
/**
* defineListenablePropertyGetter(obj, prop, getDefault, asGetter)
* 定义可监听属性的 getter ; 该方法一般经常用于:一些可监听属性在被定义时,还不能定义 getDefault 选项,只能在稍后某个时刻定义 getDefault 选项,此时便可用此函数来简化重新定义 getter 的操作;
* @param obj : Object 必选;要在其上定义属性的对象。
* @param prop : string 必选;要定义的属性的名称。
* @param getDefault ?:(thisValue)=>PropValue 可选;在获取 prop 属性的值时,如果 prop 属性的值不存在 ,则会通过 该函数获取默认的值;
* @param asGetter ?: boolean 可选;是否将 getDefault 作为 getter
*/
export function defineListenablePropertyGetter<T extends object>(obj:T, prop:string, getDefault?:(this:T,thisValue:T)=>any, asGetter?:boolean):void;
/**
* 生成唯一的标识符
* @returns {string}
*/
export function createUniqueIdentifier():string;
declare global {
interface ControllablePromise<T> extends Promise<T>{
resolve(value?: T | PromiseLike<T>):void;
reject(reason?: any):void;
clearAdditions():void;
}
}
/**
* createControllablePromise(executor ?:(resolve, reject)=>Void)
* 创建外部可控制的改变 Promise 状态 Status 的 Promise 对象;该 Promise 对象在 状态 未完成之前,会 resolve、reject、clearAdditions 三个方法,当 Promise 的状态完成时,resolve、reject、clearAdditions 这三个方法会自动被删除;其中 clearAdditions 方法是用来 清除 该实例的 resolve、reject、clearAdditions 这三个方法的;
*
* @param executor ?: (resolve, reject)=>Void 可选;executor是带有 resolve 和 reject 两个参数的函数 。Promise构造函数执行时立即调用executor 函数,
* @param statusCompletesImmediately ?: boolean 可选;默认值:true; 该参数表示在 executor 函数中是否会立即(同步)调用 resolve 或 reject ;如果是,则会把 executor 函数变成异步执行,以来避免在执行 clearAdditions 时引用 还未创建的 真实的 promise 实例;
* @returns Promise 返回一个带有 resolve、reject 和 clearAdditions 三个方法的 Promise 实例,在该实例的 状态没有改变之前 ,通过 resolve 和 reject 这两个方法,可以改变 Promise 的状态,并且会自动调用 clearAdditions 方法来清除 resolve、reject、clearAdditions 这三个方法; clearAdditions 方法用来清除 resolve、reject 和 clearAdditions 这三个方法的
*/
export function createControllablePromise<T>(executor?:(resolve: (value?: T | PromiseLike<T>) => void, reject: (reason?: any) => void) => void,statusCompletesImmediately?:boolean): ControllablePromise<T>;
/**
* 定义代理属性; 给 对象 proxy 增加 能够代理 target 对象 的 属性 prop;
* 当在 访问或配置 proxy 对象上的 prop 属性时,会将操作转发到 target 对象的 prop 属性;
*
* @param proxy : Object 必选;会在该对象上添加代理属性 prop
* @param target : Object 必选;被代理的对象
* @param prop : Property 必选;代理属性的名字;
* @param options ?: ProxyOptions 代理属性的配置选项
*
* ProxyOptions = {get:boolean,set:boolean,configurable:boolean,enumerable:boolean,getDefault,setDefault}
* get:boolean 可选;默认值:true; 表示是否要定义 get 的代理;
* set:boolean 可选;默认值:true; 表示是否要定义 set 的代理;
* configurable:boolean 可选;默认值:true; 表示该属性描述符的类型是否可以被改变并且该属性可以从对应对象中删除。
* enumerable:boolean 可选;默认值:true; 表示当在枚举相应对象上的属性时该属性是否显现。
* getDefault:any 可选;当 target 的属性 prop 为 undefined 时,proxy 会返回默认值 getDefault
* setDefault:any 可选;当给代理对象 proxy 的 prop 属性 设置的 新值是 undefined 时,会将默认值 setDefault 设置 到 target 对象的 prop 属性上;
*
* @returns proxy : Object 传递给函数的 代理对象 proxy
*/
export function defineProxyProperty(proxy: object, target: object, prop: string, options?: ProxyOptions): any;
/**
*
* 接口1:defineProxyProperties(proxy,target,propArray,options)
* @param proxy : Object 必选;会在该对象上添加代理属性 prop
* @param target : Object 必选;被代理的对象
* @param propArray : [string] 必选;要定义的代理属性的名字的列表。
* @param options ?: ProxyOptions 可选;所有代理属性的配置选项
*
* @returns proxy : Object 传递给函数的 代理对象 proxy
*/
export function defineProxyProperties(proxy: object, target: object, props: string[], options?: ProxyOptions): any;
/**
* 批量定义代理属性
*
* 接口2:defineProxyProperties(proxy,target,propOptions)
* @param proxy : Object 必选;会在该对象上添加代理属性 prop
* @param target : Object 必选;被代理的对象
* @param propOptions : {propName:ProxyOptions} 必选;要定义的代理属性的配置对象;以该配置对象的属性名为 要配置的属性的名字,以其值为 本配置的属性的 配置选项
* @returns proxy : Object 传递给函数的 代理对象 proxy
*/
export function defineProxyProperties(proxy: object, target: object, propOptions: { [prop: string]: ProxyOptions }): any;