mirror of https://github.com/sveltejs/svelte
fix bind:group with duplicated values (#4877)
parent
e75831201e
commit
787ece66a4
@ -0,0 +1,81 @@
|
|||||||
|
export default {
|
||||||
|
html: `
|
||||||
|
<p>Checked: </p>
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
|
<input type='checkbox' value='a'>a<br>
|
||||||
|
<input type='checkbox' value='b'>b<br>
|
||||||
|
<input type='checkbox' value='c'>c<br>
|
||||||
|
<input type='checkbox' value='d'>d<br>
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
|
<input type='checkbox' value='a'>a<br>
|
||||||
|
<input type='checkbox' value='b'>b<br>
|
||||||
|
<input type='checkbox' value='c'>c<br>
|
||||||
|
<input type='checkbox' value='d'>d<br>
|
||||||
|
`,
|
||||||
|
|
||||||
|
async test({ assert, component, target, window }) {
|
||||||
|
const inputs = target.querySelectorAll("input");
|
||||||
|
const p = target.querySelector("p");
|
||||||
|
|
||||||
|
assert.equal(inputs[0].checked, false);
|
||||||
|
assert.equal(inputs[1].checked, false);
|
||||||
|
assert.equal(inputs[2].checked, false);
|
||||||
|
assert.equal(inputs[3].checked, false);
|
||||||
|
|
||||||
|
assert.equal(inputs[4].checked, false);
|
||||||
|
assert.equal(inputs[5].checked, false);
|
||||||
|
assert.equal(inputs[6].checked, false);
|
||||||
|
assert.equal(inputs[7].checked, false);
|
||||||
|
|
||||||
|
const event = new window.Event("change");
|
||||||
|
|
||||||
|
inputs[0].checked = true;
|
||||||
|
await inputs[0].dispatchEvent(event);
|
||||||
|
|
||||||
|
assert.htmlEqual(p.innerHTML, `Checked: a`);
|
||||||
|
|
||||||
|
assert.equal(inputs[0].checked, true);
|
||||||
|
assert.equal(inputs[1].checked, false);
|
||||||
|
assert.equal(inputs[2].checked, false);
|
||||||
|
assert.equal(inputs[3].checked, false);
|
||||||
|
|
||||||
|
assert.equal(inputs[4].checked, true);
|
||||||
|
assert.equal(inputs[5].checked, false);
|
||||||
|
assert.equal(inputs[6].checked, false);
|
||||||
|
assert.equal(inputs[7].checked, false);
|
||||||
|
|
||||||
|
inputs[3].checked = true;
|
||||||
|
await inputs[3].dispatchEvent(event);
|
||||||
|
|
||||||
|
assert.htmlEqual(p.innerHTML, `Checked: a,d`);
|
||||||
|
|
||||||
|
assert.equal(inputs[0].checked, true);
|
||||||
|
assert.equal(inputs[1].checked, false);
|
||||||
|
assert.equal(inputs[2].checked, false);
|
||||||
|
assert.equal(inputs[3].checked, true);
|
||||||
|
|
||||||
|
assert.equal(inputs[4].checked, true);
|
||||||
|
assert.equal(inputs[5].checked, false);
|
||||||
|
assert.equal(inputs[6].checked, false);
|
||||||
|
assert.equal(inputs[7].checked, true);
|
||||||
|
|
||||||
|
inputs[4].checked = false;
|
||||||
|
await inputs[4].dispatchEvent(event);
|
||||||
|
|
||||||
|
assert.htmlEqual(p.innerHTML, `Checked: d`);
|
||||||
|
|
||||||
|
assert.equal(inputs[0].checked, false);
|
||||||
|
assert.equal(inputs[1].checked, false);
|
||||||
|
assert.equal(inputs[2].checked, false);
|
||||||
|
assert.equal(inputs[3].checked, true);
|
||||||
|
|
||||||
|
assert.equal(inputs[4].checked, false);
|
||||||
|
assert.equal(inputs[5].checked, false);
|
||||||
|
assert.equal(inputs[6].checked, false);
|
||||||
|
assert.equal(inputs[7].checked, true);
|
||||||
|
},
|
||||||
|
};
|
@ -0,0 +1,19 @@
|
|||||||
|
<script>
|
||||||
|
let foo = [];
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<p>Checked: {foo}</p>
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
|
<input type='checkbox' bind:group={foo} value='a'>a<br>
|
||||||
|
<input type='checkbox' bind:group={foo} value='b'>b<br>
|
||||||
|
<input type='checkbox' bind:group={foo} value='c'>c<br>
|
||||||
|
<input type='checkbox' bind:group={foo} value='d'>d<br>
|
||||||
|
|
||||||
|
<hr>
|
||||||
|
|
||||||
|
<input type='checkbox' bind:group={foo} value='a'>a<br>
|
||||||
|
<input type='checkbox' bind:group={foo} value='b'>b<br>
|
||||||
|
<input type='checkbox' bind:group={foo} value='c'>c<br>
|
||||||
|
<input type='checkbox' bind:group={foo} value='d'>d<br>
|
Loading…
Reference in new issue