Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 | 1x 1x 1x 1x 1x 2x 1x 1x 1x 2x 2x 1x 1x | /**
* 以闭包机制构建一个条件触发管理器
* - 条件触发管理器本身是一个函数
* - 条件触发管理器作用机制类似 jQuery.ready
* - 传入 function 作为条件触发后的回调
* - 可接收条件触发函数传递的 1 个参数
* - 调用条件触发管理器的 done 方法来激活回调条件
* - 之前插入管理器的回调函数按队列顺序执行
* - 之后插入管理器的回调函数立即执行
* - done 方法可接收 1 个参数传给回调方法
* @module setPrepare
* @returns {Function} 条件触发管理器函数
* @example
* import { setPrepare } from '@spore-ui/tskit';
* // 生成一个管理器函数 timeReady
* var timeReady = setPrepare();
*
* // 设置条件为2秒后就绪
* setTimeout(() => {
* timeReady.done('ready');
* }, 2000);
*
* // 调用管理器函数 timeReady,插入要执行的任务函数
* timeReady((str) => {
* // 2 秒后输出 1 ready
* console.info(1, str);
* });
*
* // 调用管理器函数 timeReady,插入要执行的任务函数
* timeReady((str) => {
* // 2 秒后输出 2 ready
* console.info(2, str);
* });
*
* // 2100ms 后执行
* setTimeout(() => {
* // 调用管理器函数 timeReady,插入要执行的任务函数
* timeReady((str) => {
* // 立即执行,输出 3 ready
* console.info(3, str);
* });
* }, 2100);
*/
/**
* 激活任务管理器的触发条件,在此之前插入管理器的任务按队列顺序执行,之后插入的任务函数立即执行。
* @method prepare#ready
* @memberof prepare
*/
export type TypeReadyFn = {
done: Function;
(fn: Function): void;
};
export function setPrepare(): TypeReadyFn {
const queue: Function[] = [];
let condition = false;
let payload: unknown;
const attampt = (fn: Function) => {
if (condition) {
fn(payload);
} else {
queue.push(fn);
}
};
attampt.done = (data: unknown) => {
condition = true;
payload = data;
while (queue.length) {
const fn = queue.shift();
fn(payload);
}
};
return attampt;
}
export default setPrepare;
|