从django-admin中选择另一个外键来过滤foreignkey字段?

时间:2010-07-10 02:15:05

标签: python django django-models foreign-keys

我有下一个型号

class Region(models.Model):
    nombre = models.CharField(max_length=25)

class Departamento(models.Model):
    nombre = models.CharField(max_length=25)
    region = models.ForeignKey(Region)

class Municipio(models.Model):
    nombre = models.CharField(max_length=35)
    departamento = models.ForeignKey(Departamento)

我需要根据所选区域过滤Departamento中的选项,并根据选定的Departamento过滤Municipio中的选项。

可能吗?

谢谢大家!

1 个答案:

答案 0 :(得分:2)

假设您正在谈论在一系列选择框中执行此操作:

创建两个视图,一个返回包含给定区域的Departamentos的响应。另一个做同样的事情,但对于Departamento中的Municipios来说

# views.py
from django.core import serializers

def departamentos_por_region(request, region_id):
    region = get_object_or_404(Region, id=region_id)
    departamentos = Departamento.objects.filter(region=region)
    return render_to_reponse("format_as_option_list.html",
                             {'departamentos': departamentos})

def municipios_por_departamento(request, departamento_id):
    # basically the same as above

我假设您在初始页面视图中填写了区域选择框,因此不需要特殊视图。

模板应将departamentos格式化为html选项列表。

假设初始页面视图中的HTML看起来像:

<select id='regions'>
  <option value='1'>Region 1</option>
  <option value='2'>Region 2</option>
</select>
<select id='departamentos'>
</select>
<select id='municipios'>
</select>

你会使用一些javascript(在jQuery中):

// this isn't tested code and likely contains an error or two
$('#regions').change(function(){

    // Region has changed, so reset Departamentos and Municipios
    $('#departamentos').html("")
    $('#municipios').html("")

    // now update the departamentos
    $.get('/ajax/departamentos_por_region/' +  $('#regions').val(),
          function(data) {
              ('#departamentos').html(data)    
          };     
    );
});

为Municipios和Departamentos做同样的事。

您可能还希望在没有可用选项的情况下执行禁用字段等操作,并处理没有返回任何离开或市政的情况。