[英]Django: to pass data JSON from view to javascript
我有我的模特
class Calendar(models.Model):
name = models.CharField(_('name'), max_length=50)
class Event(models.Model):
....
calendar = models.ForeignKey(Calendar, verbose_name=_('categorie'))
和我的看法:
event_list = []
events = Event.objects.all()
for event in events:
event_list.append({
'categorie': event.calendar
})
return http.HttpResponse(json.dumps(event_list),
content_type='application/json')
我尝试在JavaScript文件中返回event.categorie,但是它无法正常运行Alert(event.categorie)显示未定义。...
如果我打印event_list,我有
{'categorie': <Calendar: thermique>}
问题来自models.ForeignKey?
您不能将Calendar实例转储到json。 您应该得到错误TypeError <Calendar: thermique> is not JSON serializable
。
您需要将Calendar实例转换为简单类型的dict。 例如,将方法as_dict
添加到Calendar:
class Calendar(models.Model):
name = models.CharField(_('name'), max_length=50)
def as_dict(self):
return {
'id': self.id,
'name': self.name,
}
并在您的代码中使用它:
for event in events:
event_list.append({
'categorie': event.calendar.as_dict(),
})
它只是日历名称
由于您只需要日历名称,因此您可以对查询进行一些修改以使用values
但是真正的问题可能是通过解决查询集而引起的
events = Event.objects.values('calendar__name')
return http.JsonResponse(status=200,
{'categories': json.dumps(list(events))})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.