将Django中的字符串列表传递给Javascript

栏目: Python · 发布时间: 7年前

内容简介:翻译自:https://stackoverflow.com/questions/21150133/pass-a-list-of-string-from-django-to-javascript

我的Django对象有一个属性“City”.我正在尝试获取城市列表并使用Jquery在模板中捕获它(在X轴上的图表中使用).

我的问题是我无法摆脱unicode并引用列表.

(我设法为一个单一的价值做).相反,我坚持这个:

[“[[u’Paris’],[u’Lyon’]]”]

我已经尝试了很多东西,包括JSON.没有成功.

我的看法:

(实际上,其中一个尝试..)

def barchart1(request):
    city_array =[]
    for i in [1,MyObject.objects.count()]:
        objet = get_object_or_404(MyObject, pk=i)

        cities = [objet.city.city_name]
        city_array.append(cities)

return render (request, 'plot3/plot_page.html', {"city_array" : city_array})

我的JS:

<script type="text/javascript">
    var cities = ["{{ city_array }}"];
</script>

以下是JS如何读取视图发送的上下文

[“[[u’Paris’],[u’Lyon’]]”]

这是我想得到的

[‘巴黎’,’里昂’]

它必须是简单的东西,但我无法弄清楚如何做到这一点.

其他帖子不处理字符串列表.

知道我该怎么办?

在模板中执行{{city_array}}时,列表将转换为字符串.这是通过在列表上调用repr()来完成的,该列表以递归方式调用其内容上的repr().因为你的字符串是unicode,你会看到那些unicode文字,u’Paris’.

执行此操作的“正确”方法是将数据编码为json,例如在您的视图中:

import json
# ...
json_cities = json.dumps(city_array)
# ...
return render (request, 'plot3/plot_page.html', {"city_array" : json_cities})

然后呢

var cities = {{ city_array|safe }};

在模板中.

请注意:不要将此用于用户控制器数据!有关详细信息,请参阅 XSS Cheat Sheet by OSWASPDjango ticket 17419 的讨论.为了防止XSS,你可以使用像 SafeJSONEncoder from the django-cms project 这样的东西.

翻译自:https://stackoverflow.com/questions/21150133/pass-a-list-of-string-from-django-to-javascript


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

系统分析与设计方法

系统分析与设计方法

惠滕 / 孙慧、肖刚 / 机械工业出版社 / 2004-9 / 69.00元

本书是介绍信息系统分析和设计原理、方法、技术、工具和应用的力作,自问世以来,广受欢迎,以至于一版再版,延续至今。 本书采用一个完整的案例研究,以整个信息系统构件(基于Zachman框架)和信息系统开发生命周期(FAST方法学)为主线,详细探讨了系统开发生命周期的前期、中期和后期以及跨生命周期的活动。另外,书中第一章都提供了大量的练习题、讨论题、研究题和小型案例,以加深读者对书中所述理论的实际应用和......一起来看看 《系统分析与设计方法》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具