Django:使用get()方法的外键值

时间:2019-03-11 12:45:41

标签: python ajax django

我需要知道如何使用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做的吗?

谢谢!

0 个答案:

没有答案