diff --git a/.changeset/thick-dryers-kiss.md b/.changeset/thick-dryers-kiss.md new file mode 100644 index 000000000000..bbdc765b4e0c --- /dev/null +++ b/.changeset/thick-dryers-kiss.md @@ -0,0 +1,5 @@ +--- +'svelte': patch +--- + +fix: don't emit assignment warnings for bindings diff --git a/packages/svelte/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js b/packages/svelte/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js index 66ea2c4941a4..5ac33e629e82 100644 --- a/packages/svelte/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js +++ b/packages/svelte/src/compiler/phases/3-transform/client/visitors/AssignmentExpression.js @@ -169,6 +169,17 @@ function build_assignment(operator, left, right, context) { } } + // special case — ignore `bind:prop={getter, (v) => (...)}` / `bind:value={x.y}` + if ( + path.at(-1) === 'Component' || + path.at(-1) === 'SvelteComponent' || + (path.at(-1) === 'ArrowFunctionExpression' && + path.at(-2) === 'SequenceExpression' && + (path.at(-3) === 'Component' || path.at(-3) === 'SvelteComponent')) + ) { + should_transform = false; + } + if (left.type === 'MemberExpression' && should_transform) { const callee = callees[operator]; diff --git a/packages/svelte/src/internal/client/dev/assign.js b/packages/svelte/src/internal/client/dev/assign.js index cf8c31a941dd..fc1b647f78ca 100644 --- a/packages/svelte/src/internal/client/dev/assign.js +++ b/packages/svelte/src/internal/client/dev/assign.js @@ -1,3 +1,4 @@ +import { untrack } from '../runtime.js'; import * as w from '../warnings.js'; import { sanitize_location } from './location.js'; @@ -23,7 +24,12 @@ function compare(a, b, property, location) { * @param {string} location */ export function assign(object, property, value, location) { - return compare((object[property] = value), object[property], property, location); + return compare( + (object[property] = value), + untrack(() => object[property]), + property, + location + ); } /** @@ -33,7 +39,12 @@ export function assign(object, property, value, location) { * @param {string} location */ export function assign_and(object, property, value, location) { - return compare((object[property] &&= value), object[property], property, location); + return compare( + (object[property] &&= value), + untrack(() => object[property]), + property, + location + ); } /** @@ -43,7 +54,12 @@ export function assign_and(object, property, value, location) { * @param {string} location */ export function assign_or(object, property, value, location) { - return compare((object[property] ||= value), object[property], property, location); + return compare( + (object[property] ||= value), + untrack(() => object[property]), + property, + location + ); } /** @@ -53,5 +69,10 @@ export function assign_or(object, property, value, location) { * @param {string} location */ export function assign_nullish(object, property, value, location) { - return compare((object[property] ??= value), object[property], property, location); + return compare( + (object[property] ??= value), + untrack(() => object[property]), + property, + location + ); } diff --git a/packages/svelte/tests/runtime-runes/samples/proxy-coercive-assignment-warning/Test.svelte b/packages/svelte/tests/runtime-runes/samples/proxy-coercive-assignment-warning/Test.svelte new file mode 100644 index 000000000000..c2b06202aeb3 --- /dev/null +++ b/packages/svelte/tests/runtime-runes/samples/proxy-coercive-assignment-warning/Test.svelte @@ -0,0 +1,11 @@ + diff --git a/packages/svelte/tests/runtime-runes/samples/proxy-nullish-coalescing-assignment-warning/_config.js b/packages/svelte/tests/runtime-runes/samples/proxy-coercive-assignment-warning/_config.js similarity index 79% rename from packages/svelte/tests/runtime-runes/samples/proxy-nullish-coalescing-assignment-warning/_config.js rename to packages/svelte/tests/runtime-runes/samples/proxy-coercive-assignment-warning/_config.js index a6d79c05ed31..ad7bdc654a0b 100644 --- a/packages/svelte/tests/runtime-runes/samples/proxy-nullish-coalescing-assignment-warning/_config.js +++ b/packages/svelte/tests/runtime-runes/samples/proxy-coercive-assignment-warning/_config.js @@ -6,19 +6,19 @@ export default test({ dev: true }, - html: ``, + html: `