要将一些上下文数据传递给 javascript 代码,您必须以 javascript(即 JSON)“理解”的方式对其进行序列化。您还需要使用safe
Jinja 过滤器将其标记为安全,以防止您的数据被 htmlescaped。
您可以通过执行以下操作来实现此目的:
风景
import json
@app.route('/')
def my_view():
data = [1, 'foo']
return render_template('index.html', data=json.dumps(data))
模板
<script type="text/javascript">
function test_func(data) {
console.log(data);
}
test_func({{ data|safe }})
</script>
编辑 - 确切答案
因此,要准确实现您想要的(遍历项目列表,并将它们传递给 javascript 函数),您需要分别序列化列表中的每个项目。您的代码将如下所示:
风景
import json
@app.route('/')
def my_view():
data = [1, "foo"]
return render_template('index.html', data=map(json.dumps, data))
模板
{% for item in data %}
<span onclick=someFunction({{ item|safe }});>{{ item }}</span>
{% endfor %}
编辑 2
在我的示例中,我使用Flask
,我不知道您使用的是什么框架,但您明白了,您只需使其适合您使用的框架。
编辑 3(安全警告)
永远不要对用户提供的数据执行此操作,仅对受信任的数据执行此操作!
否则,您会将您的应用程序暴露给 XSS 漏洞!