我需要知道如何使用get方法获取外键字段的值而不是ID。
我正在将一个查询集从视图发送到模板作为JsonResponse。特定的实例信息,所以我使用get()方法
def TareaDetailView(request):
ID = request.POST.get('id')
tareas_todas = Tareas.objects.values()
tarea = tareas_todas.filter(pk=ID).get()
return JsonResponse({'tarea': tarea})
例如,我在浏览器上获取了信息,但字段名称从“ empresa”更改为“ empresa_id”。
这是我的模型,带有原始字段名称。
class Tareas(models.Model):
creador = models.ForeignKey(User, blank=True, null=True, on_delete=models.CASCADE)
destinatario = models.ForeignKey(User, related_name='destinatario', blank=True, null=True, on_delete=models.CASCADE)
titulo = models.CharField(max_length=100, blank=True, null=True)
tarea = models.TextField(max_length=500, blank=True, null=True)
resuelto = models.BooleanField(default=True)
fecha_creacion = models.DateField(default=datetime.date.today, blank=True, null=True)
fecha_limite = models.DateField(default=datetime.date.today, blank=True, null=True)
fecha_resuelto = models.DateField(default=datetime.date.today, blank=True, null=True)
empresa = models.ForeignKey("Contactos", blank=True, null=True, on_delete=models.CASCADE)
persona_empresa = models.ForeignKey("Personas", blank=True, null=True, on_delete=models.CASCADE)
这就是我可以在浏览器控制台上检查的内容。
tarea:
creador_id: 1
destinatario_id: 1
empresa_id: 6
fecha_creacion: "2019-03-10"
fecha_limite: "2019-03-15"
fecha_resuelto: "2019-03-10"
id: 210
persona_empresa_id: 3691
resuelto: false
tarea: "Habrá que hacer alguna cosa maravillosa."
titulo: "Esta es una tarea de prueba"
这是我用来获取数据并将其显示在模板中的Ajax。
<script>
$(function(){
$('.show_tarea').on('click', function (e) {
e.preventDefault();
let tarea_id = $(this).attr('id');
$.ajax({
url:'/catalog/tareas-detail/',
type:'POST',
data: $('#form_tarea_'+tarea_id).serialize(),
success:function(response){
console.log(response);
$('.show_tarea').trigger("reset");
openModal(response);
},
error:function(){
console.log('something went wrong here');
},
});
});
});
function openModal(tarea_data){
$('#creador').text(tarea_data.tarea.creador_id);
$('#destinatario').text(tarea_data.tarea.destinatario_id);
$('#titulo').text(tarea_data.tarea.titulo);
$('#tarea').text(tarea_data.tarea.tarea);
$('#resuelto').text(tarea_data.tarea.resuelto);
$('#fecha_creacion').text(tarea_data.tarea.fecha_creacion);
$('#fecha_limite').text(tarea_data.tarea.fecha_limite);
$('#fecha_resuelto').text(tarea_data.tarea.fecha_resuelto);
$('#empresa').text(tarea_data.tarea.empresa_id);
$('#persona_empresa').text(tarea_data.tarea.persona_empresa_id);
$('#modal_tareas').modal('show');
};
</script>
首先:我想知道如何获取外键值而不是ID。 第二:为什么归档名称发生变化?这是jsonresponse做的吗?
谢谢!