fix: style directive not reactive in {#each} loop (#7140)

pull/7141/head
Tan Li Hau 3 years ago committed by GitHub
parent 815bc7ef6e
commit dc06ea916e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -199,7 +199,7 @@ export default class ElementWrapper extends Wrapper {
} }
// add directive and handler dependencies // add directive and handler dependencies
[node.animation, node.outro, ...node.actions, ...node.classes].forEach(directive => { [node.animation, node.outro, ...node.actions, ...node.classes, ...node.styles].forEach(directive => {
if (directive && directive.expression) { if (directive && directive.expression) {
block.add_dependencies(directive.expression.dependencies); block.add_dependencies(directive.expression.dependencies);
} }

@ -1,18 +1,25 @@
export default { export default {
html: ` html: `
<p style="color: red;"></p> <p style="color: red;"></p>
<p style="color: red;"></p>
`, `,
test({ assert, component, target, window }) { test({ assert, component, target, window }) {
const p = target.querySelector('p'); const [p1, p2] = target.querySelectorAll('p');
let styles = window.getComputedStyle(p); assert.equal(window.getComputedStyle(p1).color, 'red');
assert.equal(styles.color, 'red'); assert.equal(window.getComputedStyle(p2).color, 'red');
component.color = 'blue'; component.color = 'blue';
assert.htmlEqual(target.innerHTML, '<p style="color: blue;"></p>'); assert.htmlEqual(
target.innerHTML,
`
<p style="color: blue;"></p>
<p style="color: blue;"></p>
`
);
styles = window.getComputedStyle(p); assert.equal(window.getComputedStyle(p1).color, 'blue');
assert.equal(styles.color, 'blue'); assert.equal(window.getComputedStyle(p2).color, 'blue');
} }
}; };

@ -3,3 +3,7 @@
</script> </script>
<p style:color /> <p style:color />
{#each [1] as _}
<p style:color />
{/each}

Loading…
Cancel
Save