2016-06-29 9 views
-1

Ich habe beobachtet, dass beim Schreiben von JS in Skript-Tags in die Vorlage das Skript ausgeführt wird, wenn sie in die Vorlage eingefügt werden.EmberJS 1.13 Templating - Skriptelemente aus htmlSafe string führt JS nicht aus

habe ich versucht, dies in meine Komponente schreiben:

test: Ember.String.htmlSafe("<script>console.log('Hello World')</script>")

Und in meiner Vorlage:

{{test}}

Diese in den DOM einfügen, aber den Code nicht ausgeführt . Ich dachte, es war, weil HTMLBars nicht Script-Tags in der Vorlage erlauben, aber nur

<script>console.log('Hello World')</script>

in die Schablone schreiben selbst die JS innerhalb laufen.

Kann mir jemand sagen, ob es einen Weg gibt, dies zu erreichen oder eine Erklärung zu geben, warum dies geschieht? Danke im Voraus.

Antwort

0

Wenn Sie mit JavaScript-Zeichenfolge arbeiten, können Sie zusätzliche {{{}}} verwenden, um sie richtig anzuzeigen. Sichere Vorlagenausgabe mit:

{{{test}}} 

Das wird die Arbeit machen. Haben Sie einen Blick auf dieses Blog

http://www.kaspertidemann.com/html-safe-strings-in-handlebars/

+0

Vielen Dank für die schnelle Antwort. Die Verwendung von Ember.String.htmlSafe mit den doppelten Klammern umgeht auch die Entweichen und zeigt sie richtig an. Das Skript-Tag erscheint gut, aber es ist der JS innerhalb, der nicht ausgeführt wird. Ich habe auch versucht, die dreifachen Klammern zu überprüfen, und die JS läuft auch nicht. – Jan

+1

Ich bin mir nicht sicher, was Sie erreichen möchten? Allgemein in ember können Sie einen Helfer schreiben, der den String entkommt oder eine triple Klammer verwendet. Möchten Sie, dass das Skript ausgeführt wird, da Ihre Frage besagt, dass HTML.safe nicht ausgeführt wird? es sollte nicht laufen, deshalb ist es sicher lol –

0

schreiben Es gibt keine Notwendigkeit, das zu tun. Sie können entweder JavaScript-Code von Ihrer Komponente ausführen oder in Ihrer Vorlage den Tag <script> verwenden (wie in Ihrer Frage beschrieben).