gpt4 book ai didi

backbone.js - 渲染字段时Wtforms转义包含自变量js模板的value参数

转载 作者:行者123 更新时间:2023-12-03 16:54:36 26 4
gpt4 key购买 nike

我正在使用Flask,WTForms和Backbone.js创建我的应用程序。我是第一次与Backbonejs合作。

我创建了一个Backbone js模板来显示数据及其对应的表单。

    <%= my_field1 %>
<%= my_field2 %>
<form>
<input type="text" value="<%= my_field1 %>"/>
<input type="text" value="<%= my_field2 %>"/>
</form>


我正在使用WTForms和Jinja2呈现我的表单。为了给出初始值,我正在这样做

    {{ field1(value="<%= my_field1 %>") | safe }}
{{ field1(value="<%= my_field1 %>") | safe }}


这是问题的根源,因为<%在渲染时被转义了。如何阻止wtforms / jinja转义?

最佳答案

我看了看WTForms的源代码,是的,它作为呈现的一部分转义了HTML字符,您可以通过调用该字段来实现。因此,jinja的“安全”参数作用太迟了。

您可以通过创建自定义窗口小部件来呈现字段来解决此问题:

http://wtforms.simplecodes.com/docs/0.6/widgets.html#custom-widgets

我专心为您编写了一个小部件-很抱歉,我没有运行此代码,但这足以使您朝正确的方向前进。

如果遇到麻烦,请确保查看WTForms的源代码:注释很好,没有很多,您可以从那里婴儿床。 (我做到了!)

from wtforms.widgets.core import HTMLString 

# Custom widget display
def input_field_with_unescaped_value(field, **kwargs):

value = kwargs.pop('value', field._value())
unescaped_output = u' value="%s"' % value if value else ''

return HTMLString(u'<input %s%s>%s</input>' % \
(html_params(name=field.name, **kwargs), \
unescaped_output, \
unicode(field._value()))

# and here's how you use it in a form
class MyForm(Form):
field1 = TextField(u'Thingy', widget=input_field_with_unescaped_value)

关于backbone.js - 渲染字段时Wtforms转义包含自变量js模板的value参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13323280/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com