本文整理匯總了TypeScript中@glimmer/runtime.CapturedNamedArguments類的典型用法代碼示例。如果您正苦於以下問題:TypeScript CapturedNamedArguments類的具體用法?TypeScript CapturedNamedArguments怎麽用?TypeScript CapturedNamedArguments使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了CapturedNamedArguments類的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: processComponentArgs
export function processComponentArgs(namedArgs: CapturedNamedArguments) {
let keys = namedArgs.names;
let attrs = namedArgs.value();
let props = Object.create(null);
let args = Object.create(null);
props[ARGS] = args;
for (let i = 0; i < keys.length; i++) {
let name = keys[i];
let ref = namedArgs.get(name);
let value = attrs[name];
if (typeof value === 'function' && value[ACTION]) {
attrs[name] = value;
} else if (ref[UPDATE]) {
attrs[name] = new MutableCell(ref, value);
}
args[name] = ref;
props[name] = value;
}
props.attrs = attrs;
return props;
}
示例2: handler
handler(event: Event): boolean {
let { actionName, namedArgs } = this;
let bubbles = namedArgs.get('bubbles');
let preventDefault = namedArgs.get('preventDefault');
let allowedKeys = namedArgs.get('allowedKeys');
let target = this.getTarget();
let shouldBubble = bubbles.value() !== false;
if (!isAllowedEvent(event, allowedKeys.value())) {
return true;
}
if (preventDefault.value() !== false) {
event.preventDefault();
}
if (!shouldBubble) {
event.stopPropagation();
}
run(() => {
let args = this.getActionArgs();
let payload = {
args,
target,
name: null,
};
if (typeof actionName[INVOKE] === 'function') {
flaggedInstrument('interaction.ember-action', payload, () => {
actionName[INVOKE].apply(actionName, args);
});
return;
}
if (typeof actionName === 'function') {
flaggedInstrument('interaction.ember-action', payload, () => {
actionName.apply(target, args);
});
return;
}
payload.name = actionName;
if (target.send) {
flaggedInstrument('interaction.ember-action', payload, () => {
target.send.apply(target, [actionName, ...args]);
});
} else {
assert(
`The action '${actionName}' did not exist on ${target}`,
typeof target[actionName] === 'function',
);
flaggedInstrument('interaction.ember-action', payload, () => {
target[actionName].apply(target, args);
});
}
});
return shouldBubble;
}
示例3: getTarget
getTarget() {
let { implicitTarget, namedArgs } = this;
let target;
if (namedArgs.has('target')) {
target = namedArgs.get('target').value();
} else {
target = implicitTarget.value();
}
return target;
}
示例4: getEventName
getEventName() {
return this.namedArgs.get('on').value() || 'click';
}