implement triples in SSR compiler, and escape HTML for regular tags

pull/198/head
Rich Harris 8 years ago
parent 23b7759160
commit c8b232f431

@ -219,6 +219,11 @@ export default function compile ( parsed, source, { filename }) {
}, },
MustacheTag ( node ) { MustacheTag ( node ) {
const { snippet } = contextualise( node.expression ); // TODO use snippet, for sourcemap support
return '${__escape( String( ' + snippet + ') )}';
},
RawMustacheTag ( node ) {
const { snippet } = contextualise( node.expression ); // TODO use snippet, for sourcemap support const { snippet } = contextualise( node.expression ); // TODO use snippet, for sourcemap support
return '${' + snippet + '}'; return '${' + snippet + '}';
}, },
@ -381,6 +386,18 @@ export default function compile ( parsed, source, { filename }) {
exports.renderCss = function () { exports.renderCss = function () {
${renderCssStatements.join( '\n\n' )} ${renderCssStatements.join( '\n\n' )}
}; };
var escaped = {
'"': '"',
"'": '&39;',
'&': '&',
'<': '&lt;',
'>': '&gt;'
};
function __escape ( html ) {
return html.replace( /["'&<>]/g, match => escaped[ match ] );
}
` ); ` );
const rendered = topLevelStatements.join( '\n\n' ); const rendered = topLevelStatements.join( '\n\n' );

@ -0,0 +1 @@
&lt;p&gt;this should be &lt;em&gt;escaped&lt;/em&gt; &amp; so should &39;this&39;&lt;/p&gt;

@ -0,0 +1 @@
&lt;p&gt;this should be &lt;em&gt;escaped&lt;/em&gt; &amp; so should &39;this&39;&lt;/p&gt;

@ -0,0 +1,3 @@
{
"foo": "<p>this should be <em>escaped</em> & so should 'this'</p>"
}

@ -0,0 +1,11 @@
<div>{{{triple}}}</div>
<script>
export default {
data () {
return {
triple: '<p>html</p>'
};
}
};
</script>
Loading…
Cancel
Save