栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何使用Modelform和Jquery在Django中获取Interdependent下拉菜单?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何使用Modelform和Jquery在Django中获取Interdependent下拉菜单?

你可能需要使用以下技术:

  • 自定义Django表单字段(在模型表单中)
  • ajax(获取记录)
  • simplejson(向ajax发送json响应)
  • jQuery(更新客户端上的组合框)
    让我们看一个示例(只是从我的脑海中未真正测试过):

型号

from django.db import modelsclass Campus(models.Model):    name = models.CharField(max_length=100, choices=choices.CAMPUSES)    def __unipre__(self):        return u'%s' % self.nameclass School(models.Model):    name = models.CharField(max_length=100)    campus = models.ForeignKey(Campus)    def __unipre__(self):        return u'%s' % self.nameclass Centre(models.Model):    name = models.CharField(max_length=100)    school = models.ForeignKey(School)    def __unipre__(self):        return u'%s' % self.name

Forms.py

import modelsfrom django import formsclass CenterForm(forms.ModelForm):    campus = forms.ModelChoiceField(queryset=models.Campus.objects.all())    school = forms.ModelChoiceField(queryset=models.School.objects.none()) # Need to populate this using jquery    centre = forms.ModelChoiceField(queryset=models.Centre.objects.none()) # Need to populate this using jquery    class meta:        model = models.Center        fields = ('campus', 'school', 'centre')

现在,在你的视图中编写一个方法,该方法为校园下的学校和学校下的中心返回json对象:

Views.py

import modelsimport simplejsonfrom django.http import HttpResponsedef get_schools(request, campus_id):    campus = models.Campus.objects.get(pk=campus_id)    schools = models.School.objects.filter(campus=campus)    school_dict = {}    for school in schools:        school_dict[school.id] = school.name    return HttpResponse(simplejson.dumps(school_dict), mimetype="application/json")def get_centres(request, school_id):    school = models.School.objects.get(pk=school_id)    centres = models.Centre.objects.filter(school=school)    centre_dict = {}    for centre in centres:        centre_dict[centre.id] = centre.name    return HttpResponse(simplejson.dumps(centre_dict), mimetype="application/json")

现在编写一个ajax / jquery方法来获取数据并填充selectHTML中的元素。

AJAX / jQuery$(document).ready(function(){    $('select[name=campus]').change(function(){        campus_id = $(this).val();        request_url = '/get_schools/' + campus_id + '/';        $.ajax({ url: request_url, success: function(data){     $.each(data, function(index, text){         $('select[name=school]').append(   $('<option></option>').val(index).html(text)          );     }); }        });        return false;    })});


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/373926.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号