diff --git a/src/compiler/compile/render_dom/wrappers/Element/StyleAttribute.ts b/src/compiler/compile/render_dom/wrappers/Element/StyleAttribute.ts index ab764a8583d0..7f9dd2ee95e1 100644 --- a/src/compiler/compile/render_dom/wrappers/Element/StyleAttribute.ts +++ b/src/compiler/compile/render_dom/wrappers/Element/StyleAttribute.ts @@ -110,8 +110,9 @@ function get_style_value(chunks: Array) { let in_url = false; let quote_mark = null; let escaped = false; + let closed = false; - while (chunks.length) { + while (chunks.length && !closed) { const chunk = chunks.shift(); if (chunk.type === 'Text') { @@ -132,6 +133,7 @@ function get_style_value(chunks: Array) { } else if (char === 'u' && chunk.data.slice(c, c + 4) === 'url(') { in_url = true; } else if (char === ';' && !in_url && !quote_mark) { + closed = true; break; } diff --git a/test/runtime/samples/inline-style-optimisation-bailout/_config.js b/test/runtime/samples/inline-style-optimisation-bailout/_config.js new file mode 100644 index 000000000000..b294e38bbc3d --- /dev/null +++ b/test/runtime/samples/inline-style-optimisation-bailout/_config.js @@ -0,0 +1,20 @@ +export default { + html: ` +

color: red

+ `, + + test({ assert, component, target, window }) { + const p = target.querySelector('p'); + + let styles = window.getComputedStyle(p); + assert.equal(styles.opacity, '0.5'); + assert.equal(styles.color, 'red'); + + component.styles = 'font-size: 20px'; + + styles = window.getComputedStyle(p); + assert.equal(styles.opacity, '0.5'); + assert.equal(styles.color, ''); + assert.equal(styles.fontSize, '20px'); + } +} \ No newline at end of file diff --git a/test/runtime/samples/inline-style-optimisation-bailout/main.svelte b/test/runtime/samples/inline-style-optimisation-bailout/main.svelte new file mode 100644 index 000000000000..35b768547e25 --- /dev/null +++ b/test/runtime/samples/inline-style-optimisation-bailout/main.svelte @@ -0,0 +1,5 @@ + + +

{styles}

\ No newline at end of file