mirror of https://github.com/sveltejs/svelte
fix: each block breaking with effects interspersed among items (#17550)
* fix: each block breaking with effects interspersed among items * test sample with interspersed non-branch effects * Apply suggestion from @Rich-Harris * use $effect.pre in sample instead --------- Co-authored-by: Rich Harris <hello@rich-harris.dev>pull/16517/merge
parent
e9d580ed40
commit
02b5d94b3a
@ -0,0 +1,5 @@
|
||||
---
|
||||
'svelte': patch
|
||||
---
|
||||
|
||||
fix: each block breaking with effects interspersed among items
|
||||
@ -0,0 +1,43 @@
|
||||
import { flushSync } from 'svelte';
|
||||
import { test } from '../../test';
|
||||
|
||||
export default test({
|
||||
async test({ assert, target }) {
|
||||
const addBtn = /** @type {HTMLElement} */ (target.querySelector('button.add'));
|
||||
const removeBtn = /** @type {HTMLElement} */ (target.querySelector('button.remove'));
|
||||
|
||||
const btnHtml = '<button class="add">add</button><button class="remove">remove</button>';
|
||||
|
||||
assert.htmlEqual(target.innerHTML, btnHtml);
|
||||
|
||||
addBtn.click();
|
||||
flushSync();
|
||||
|
||||
assert.htmlEqual(target.innerHTML, `<span>1</span>${btnHtml}`);
|
||||
|
||||
addBtn.click();
|
||||
flushSync();
|
||||
|
||||
assert.htmlEqual(target.innerHTML, `<span>1</span><span>2</span>${btnHtml}`);
|
||||
|
||||
addBtn.click();
|
||||
flushSync();
|
||||
|
||||
assert.htmlEqual(target.innerHTML, `<span>1</span><span>2</span><span>3</span>${btnHtml}`);
|
||||
|
||||
removeBtn.click();
|
||||
flushSync();
|
||||
|
||||
assert.htmlEqual(target.innerHTML, `<span>1</span><span>2</span>${btnHtml}`);
|
||||
|
||||
removeBtn.click();
|
||||
flushSync();
|
||||
|
||||
assert.htmlEqual(target.innerHTML, `<span>1</span>${btnHtml}`);
|
||||
|
||||
addBtn.click();
|
||||
flushSync();
|
||||
|
||||
assert.htmlEqual(target.innerHTML, `<span>1</span><span>2</span>${btnHtml}`);
|
||||
}
|
||||
});
|
||||
@ -0,0 +1,30 @@
|
||||
<script>
|
||||
let items = $state([]);
|
||||
|
||||
const proxy = new Proxy(items, {
|
||||
get: (target, prop) => {
|
||||
try {
|
||||
$effect.pre(() => {
|
||||
return () => {};
|
||||
});
|
||||
} catch {}
|
||||
|
||||
return Reflect.get(target, prop);
|
||||
}
|
||||
});
|
||||
|
||||
function add() {
|
||||
items.push(items.length + 1);
|
||||
}
|
||||
|
||||
function remove() {
|
||||
items.pop();
|
||||
}
|
||||
</script>
|
||||
|
||||
{#each proxy as item}
|
||||
<span>{item}</span>
|
||||
{/each}
|
||||
|
||||
<button class="add" onclick={add}>add</button>
|
||||
<button class="remove" onclick={remove}>remove</button>
|
||||
Loading…
Reference in new issue