diff --git a/packages/runtime-core/__tests__/vnode.spec.ts b/packages/runtime-core/__tests__/vnode.spec.ts index a8979e811dc..fdd23797b10 100644 --- a/packages/runtime-core/__tests__/vnode.spec.ts +++ b/packages/runtime-core/__tests__/vnode.spec.ts @@ -446,6 +446,10 @@ describe('vnode', () => { onClick: [clickHandler1, clickHandler2], onFocus: focusHandler2 }) + let props3: Data = { onClick: undefined } + expect(mergeProps(props1, props3)).toMatchObject({ + onClick: clickHandler1 + }) }) test('default', () => { diff --git a/packages/runtime-core/src/vnode.ts b/packages/runtime-core/src/vnode.ts index 0db4005c877..059d8ba3a29 100644 --- a/packages/runtime-core/src/vnode.ts +++ b/packages/runtime-core/src/vnode.ts @@ -798,6 +798,7 @@ export function mergeProps(...args: (Data & VNodeProps)[]) { const existing = ret[key] const incoming = toMerge[key] if ( + incoming && existing !== incoming && !(isArray(existing) && existing.includes(incoming)) ) { diff --git a/packages/runtime-dom/src/modules/events.ts b/packages/runtime-dom/src/modules/events.ts index 7172e3efdd2..51544dedf49 100644 --- a/packages/runtime-dom/src/modules/events.ts +++ b/packages/runtime-dom/src/modules/events.ts @@ -141,7 +141,7 @@ function patchStopImmediatePropagation( originalStop.call(e) ;(e as any)._stopped = true } - return value.map(fn => (e: Event) => !(e as any)._stopped && fn(e)) + return value.map(fn => (e: Event) => !(e as any)._stopped && fn && fn(e)) } else { return value }