fix: `event.currentTarget` always being equal to `event.target` (#11419)

fixes #11328
pull/11432/head
Hunter Johnston 3 months ago committed by GitHub
parent edefc846c3
commit 17b2f6215d
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

@ -122,22 +122,22 @@ export function handle_event_propagation(handler_element, event) {
}
});
/** @param {Element} current_target */
function next(current_target) {
/** @param {Element} next_target */
function next(next_target) {
current_target = next_target;
/** @type {null | Element} */
var parent_element =
current_target.parentNode || /** @type {any} */ (current_target).host || null;
var parent_element = next_target.parentNode || /** @type {any} */ (next_target).host || null;
try {
// @ts-expect-error
var delegated = current_target['__' + event_name];
var delegated = next_target['__' + event_name];
if (delegated !== undefined && !(/** @type {any} */ (current_target).disabled)) {
if (delegated !== undefined && !(/** @type {any} */ (next_target).disabled)) {
if (is_array(delegated)) {
var [fn, ...data] = delegated;
fn.apply(current_target, [event, ...data]);
fn.apply(next_target, [event, ...data]);
} else {
delegated.call(current_target, event);
delegated.call(next_target, event);
}
}
} finally {
@ -145,7 +145,7 @@ export function handle_event_propagation(handler_element, event) {
!event.cancelBubble &&
parent_element !== handler_element &&
parent_element !== null &&
current_target !== handler_element
next_target !== handler_element
) {
next(parent_element);
}

@ -0,0 +1,12 @@
import { test } from '../../test';
export default test({
async test({ assert, target, logs }) {
const [s1] = target.querySelectorAll('span');
s1?.click();
await Promise.resolve();
assert.deepEqual(logs, [false]);
}
});

@ -0,0 +1,13 @@
<script>
function onclick(e) {
// should log false when we click the span
console.log(e.currentTarget === e.target)
}
</script>
<button {onclick}>
<span>
Click me
</span>
</button>
Loading…
Cancel
Save