我有下一个型号
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中的选项。
可能吗?
谢谢大家!
答案 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做同样的事。
您可能还希望在没有可用选项的情况下执行禁用字段等操作,并处理没有返回任何离开或市政的情况。