2011-09-14 17 views
9

Estaba probando Jinja2 en un proyecto de Django y tengo una salida extraña. cuando me hacen la forma, algunos caracteres son codificados en HTML (< > etc.)Jinja 2 - Django Formulario: representación codifica HTML

En la plantilla:

{{ form.as_p() }} 

Se hace al navegador:

<p><label for="id_username">Utilisateur:</label> <input autocomplete="off" id="id_username" type="text" name="username" maxlength="100" /></p> <p><label for="id_password">Mot de passe:</label> <input autocomplete="off" type="password" name="password" id="id_password" /></p> 

En cuanto a las fuentes:

&amp;lt;p&amp;gt;&amp;lt;label for=&amp;quot;id_username&amp;quot;&amp;gt;Utilisateur:&amp;lt;/label&amp;gt; &amp;lt;input autocomplete=&amp;quot;off&amp;quot; id=&amp;quot;id_username&amp;quot; type=&amp;quot;text&amp;quot; name=&amp;quot;username&amp;quot; maxlength=&amp;quot;100&amp;quot; /&amp;gt;&amp;lt;/p&amp;gt; 
&amp;lt;p&amp;gt;&amp;lt;label for=&amp;quot;id_password&amp;quot;&amp;gt;Mot de passe:&amp;lt;/label&amp;gt; &amp;lt;input autocomplete=&amp;quot;off&amp;quot; type=&amp;quot;password&amp;quot; name=&amp;quot;password&amp;quot; id=&amp;quot;id_password&amp;quot; /&amp;gt;&amp;lt;/p&amp;gt; 

¿Alguien sabe este problema?

Respuesta

26

Jinja2 intenta ser seguro por HTML-escaping the data. Entonces debe usar |safefilter.

Aunque no he utilizado con Django Jinja2, creo que esto debería funcionar:

{{ form.as_p()|safe }} 
+0

Gran esto funciona bien. ¡Gracias! – Patrick

+5

@Patrick: si le pareció útil esta publicación, por favor [acéptelo] (http://meta.stackexchange.com/questions/5234/how-does-accepting-an-answer-work). –

+1

Votación máxima. ¡Me ayudó también! – Raj

Cuestiones relacionadas