diff --git a/src/compiler/compile/nodes/EventHandler.ts b/src/compiler/compile/nodes/EventHandler.ts
index 19da3d9dd7b3..bee10be659f8 100644
--- a/src/compiler/compile/nodes/EventHandler.ts
+++ b/src/compiler/compile/nodes/EventHandler.ts
@@ -44,6 +44,8 @@ export default class EventHandler extends Node {
this.reassigned = component.var_lookup.get(info.expression.name).reassigned;
}
+ } else if (this.expression.dynamic_dependencies().length > 0) {
+ this.reassigned = true;
}
} else {
this.handler_name = component.get_unique_name(`${sanitize(this.name)}_handler`);
diff --git a/test/runtime/samples/event-handler-dynamic-expression/_config.js b/test/runtime/samples/event-handler-dynamic-expression/_config.js
new file mode 100644
index 000000000000..c4d259a54246
--- /dev/null
+++ b/test/runtime/samples/event-handler-dynamic-expression/_config.js
@@ -0,0 +1,20 @@
+export default {
+ html: ``,
+
+ async test({ assert, component, target, window }) {
+ const [button] = target.querySelectorAll(
+ 'button'
+ );
+
+ const event = new window.MouseEvent('click');
+
+ await button.dispatchEvent(event);
+ assert.htmlEqual(target.innerHTML, ``);
+
+ await button.dispatchEvent(event);
+ assert.htmlEqual(target.innerHTML, ``);
+
+ await button.dispatchEvent(event);
+ assert.htmlEqual(target.innerHTML, ``);
+ },
+};
diff --git a/test/runtime/samples/event-handler-dynamic-expression/main.svelte b/test/runtime/samples/event-handler-dynamic-expression/main.svelte
new file mode 100644
index 000000000000..f53aa7aaddb0
--- /dev/null
+++ b/test/runtime/samples/event-handler-dynamic-expression/main.svelte
@@ -0,0 +1,12 @@
+
+
+
\ No newline at end of file