2011-09-14 10 views
9

私はDjangoプロジェクトでJinja2をテストしていました。 私はフォームをレンダリングするとき、一部の文字がテンプレートでエンコードされたHTML(< >など)Jinja 2 - Djangoフォーム:レンダリングエンコードHTML

です:

{{ form.as_p() }} 

それがブラウザにレンダリング:

のソースを見てみると
<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> 

&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; 

誰でもこの問題を知っていますか?

答えて

26

Jinja2は、HTML-escaping the dataで安全にしようとします。したがって、|safefilterを使用する必要があります。

私はJinja2のではDjangoを使用していないが、私はこれは動作するはずと信じて:

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

グレートこれは正常に動作します。 ありがとうございました! – Patrick

+5

@Patrick:この投稿が役に立ったら、[同意してください](http://meta.stackexchange.com/questions/5234/how-does-accepting-an-answer-work)してください。 –

+1

Upvoted。私を助けた! – Raj

関連する問題