将任务加入队列
一、作用
二、将任务加入队列
export default function enqueueTask(task: () => void): void {
if (enqueueTaskImpl === null) {
try {
// read require off the module object to get around the bundlers.
// we don't want them to detect a require and bundle a Node polyfill.
//
// 从模块对象中读取 require,以绕过打包工具。
// 我们不希望它们检测到 require 并打包 Node 的填充代码。
const requireString = ('require' + Math.random()).slice(0, 7);
const nodeRequire = module && module[requireString];
// assuming we're in node, let's try to get node's
// version of setImmediate, bypassing fake timers if any.
//
// 假设我们在 node 环境中,让我们尝试获取 node 的 setImmediate 版本,
// 如果有模拟计时器的话要绕过它。
enqueueTaskImpl = nodeRequire.call(module, 'timers').setImmediate;
} catch (_err) {
// we're in a browser
// we can't use regular timers because they may still be faked
// so we try MessageChannel+postMessage instead
//
// 我们在浏览器中,我们不能使用常规定时器,因为它们可能会被伪造,所以我们尝试使用
// MessageChannel 的 postMessage
enqueueTaskImpl = function (callback: () => void) {
if (__DEV__) {
if (didWarnAboutMessageChannel === false) {
didWarnAboutMessageChannel = true;
if (typeof MessageChannel === 'undefined') {
console.error(
'This browser does not have a MessageChannel implementation, ' +
'so enqueuing tasks via await act(async () => ...) will fail. ' +
'Please file an issue at https://github.com/facebook/react/issues ' +
'if you encounter this warning.',
);
}
}
}
const channel = new MessageChannel();
channel.port1.onmessage = callback;
channel.port2.postMessage(undefined);
};
}
}
return enqueueTaskImpl(task);
}
三、变量
1. 已警告消息通道
let didWarnAboutMessageChannel = false;
2. 入队任务实现
let enqueueTaskImpl = null;