跳到主要内容

event registry

一、作用

二、导出的常量

1. 所有本地事件

备注
export const allNativeEvents: Set<DOMEventName> = new Set();
if (enableCreateEventHandleAPI) {
allNativeEvents.add('beforeblur');
allNativeEvents.add('afterblur');
}

2. 注册名称依赖

/**
* Mapping from registration name to event name
* 从注册名映射到事件名
*/
export const registrationNameDependencies: {
[registrationName: string]: Array<DOMEventName>;
} = {};

3. 可能的注册名称

/**
* Mapping from lowercase registration names to the properly cased version,
* used to warn in the case of missing event handlers. Available
* only in __DEV__.
*
* 从小写注册名称映射到正确的大小写版本,用于在缺少事件处理程序时发出警告。仅用在开发阶段
*
* @type {Object}
*/
export const possibleRegistrationNames: {
[lowerCasedName: string]: string;
} = __DEV__ ? {} : (null as any);
// Trust the developer to only use possibleRegistrationNames in __DEV__
// 相信开发者只会在 __DEV__ 中使用 possibleRegistrationNames

三、注册两阶段事件

export function registerTwoPhaseEvent(
registrationName: string,
dependencies: Array<DOMEventName>,
): void {
registerDirectEvent(registrationName, dependencies);
registerDirectEvent(registrationName + 'Capture', dependencies);
}

四、注册直接事件

export function registerDirectEvent(
registrationName: string,
dependencies: Array<DOMEventName>,
) {
if (__DEV__) {
if (registrationNameDependencies[registrationName]) {
console.error(
'EventRegistry: More than one plugin attempted to publish the same ' +
'registration name, `%s`.',
registrationName,
);
}
}

registrationNameDependencies[registrationName] = dependencies;

if (__DEV__) {
const lowerCasedName = registrationName.toLowerCase();
possibleRegistrationNames[lowerCasedName] = registrationName;

if (registrationName === 'onDoubleClick') {
possibleRegistrationNames.ondblclick = registrationName;
}
}

for (let i = 0; i < dependencies.length; i++) {
allNativeEvents.add(dependencies[i]);
}
}