From aba5929697a2731cb5b684690617faa0da3978d8 Mon Sep 17 00:00:00 2001 From: Conduitry Date: Thu, 3 May 2018 04:01:54 -0400 Subject: [PATCH] mark elements with refs as ineligible for innerhtml (#1407) --- src/compile/nodes/Element.ts | 4 ++++ test/runtime/samples/refs-no-innerhtml/_config.js | 7 +++++++ test/runtime/samples/refs-no-innerhtml/main.html | 1 + 3 files changed, 12 insertions(+) create mode 100644 test/runtime/samples/refs-no-innerhtml/_config.js create mode 100644 test/runtime/samples/refs-no-innerhtml/main.html diff --git a/src/compile/nodes/Element.ts b/src/compile/nodes/Element.ts index bb7d71fcd7f5..2dc46c69ad0d 100644 --- a/src/compile/nodes/Element.ts +++ b/src/compile/nodes/Element.ts @@ -191,6 +191,10 @@ export default class Element extends Node { block.outros += 1; } + if (this.ref) { + this.parent.cannotUseInnerHTML(); + } + const valueAttribute = this.attributes.find((attribute: Attribute) => attribute.name === 'value'); // special case — in a case like this... diff --git a/test/runtime/samples/refs-no-innerhtml/_config.js b/test/runtime/samples/refs-no-innerhtml/_config.js new file mode 100644 index 000000000000..a1e5ddd7f1a4 --- /dev/null +++ b/test/runtime/samples/refs-no-innerhtml/_config.js @@ -0,0 +1,7 @@ +export default { + html: '
', + test ( assert, component, target ) { + const canvas = target.querySelector( 'canvas' ); + assert.equal( canvas, component.refs.foo ); + } +}; diff --git a/test/runtime/samples/refs-no-innerhtml/main.html b/test/runtime/samples/refs-no-innerhtml/main.html new file mode 100644 index 000000000000..35d9d3a54bf1 --- /dev/null +++ b/test/runtime/samples/refs-no-innerhtml/main.html @@ -0,0 +1 @@ +