Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/22.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 为什么依赖django的dropdownn不起作用_Python_Django_Django Crispy Forms - Fatal编程技术网

Python 为什么依赖django的dropdownn不起作用

Python 为什么依赖django的dropdownn不起作用,python,django,django-crispy-forms,Python,Django,Django Crispy Forms,我不知道我的代码哪里有错误。它只是没有像预期的那样工作。 我的观点 def load_cities(request): year_id = request.GET.get('year') terms = Term.objects.filter(school=request.user.school).filter(year_id=year_id).order_by('name') return render(request, 'city_dropdown_list_opti

我不知道我的代码哪里有错误。它只是没有像预期的那样工作。 我的观点

def load_cities(request):
    year_id = request.GET.get('year')
    terms = Term.objects.filter(school=request.user.school).filter(year_id=year_id).order_by('name')
    return render(request, 'city_dropdown_list_options', {'terms': terms})
我的模特

class Year(models.Model):
    
    school = models.ForeignKey(School,on_delete=models.CASCADE)
    year = models.CharField(max_length=200,unique=True)

class Term(models.Model):
    school = models.ForeignKey(School,on_delete=models.CASCADE)
    year = models.ForeignKey(Year,on_delete=models.CASCADE)
    name = models.CharField(max_length=200,unique=True) 

class Exam(models.Model):
    school = models.ForeignKey(School,on_delete=models.CASCADE)
    year = models.ForeignKey(Year,on_delete=models.SET_NULL, null=True)
    term = models.ForeignKey(Term,on_delete=models.SET_NULL, null=True)
    name = models.CharField(max_length=20)
    form = models.ManyToManyField(FormModel)
我的表格.py

    class NewExamForm(forms.ModelForm):
        class Meta:
            model = Exam
            fields = ("year","term","name","school","form")
            
            widgets = {
                'school':forms.TextInput(attrs={"class":'form-control','value':'','id':'identifier','type':'hidden'}),
                "year":forms.Select(attrs={"class":'form-control'}),
                "name":forms.TextInput(attrs={"class":'form-control'}),
                "form":forms.Select(attrs={"class":'form-control'}),
                
            }
        def __init__(self, school, *args, **kwargs):
            super(NewExamForm, self).__init__(*args, **kwargs)
            
            
            self.fields['year'] = forms.ModelChoiceField(
                queryset=Year.objects.filter(school=school))
    
            self.fields['term'].queryset = Term.objects.none()
    
            self.fields['form'] = forms.ModelMultipleChoiceField(
                queryset=FormModel.objects.filter(school=school),
                widget=forms.CheckboxSelectMultiple,
                required=True)
            
            if 'year' in self.data:
                try:
                    year = int(self.data.get('year'))
                    self.fields['term'].queryset = Term.objects.filter(school=school).filter(year_id=year).order_by('name')
                except (ValueError, TypeError):
                    pass  # invalid input from the client; ignore and fallback to empty City queryset
            elif self.instance.pk:
                self.fields['term'].queryset = self.instance.year.term_set.order_by('name')

The template

<div class="form-group">
        <form method="post" id="examForm" data-cities-url="{% url 'ajax_load_cities' %}" novalidate enctype="multipart/form-data">
        {% csrf_token %}
        <table>
          {{ form|crispy }}
        </table>
        <button type="submit">Save</button>
        </form>
        
    </div>
我已经尝试过了,但只有在我选择了一年并手动刷新所选的年份后,它才起作用,也就是在出现术语时


我试着遵循维托·弗雷塔斯的代码,但没能让它工作。任何有技术帮助的人。

我按照@evergreen的指示对脚本进行了更正,从而使其正常工作

<script>

$("#id_year").change(function () {
  var url = $("#examForm").attr("term-data");
  var yearId = $(this).val();

  $.ajax({
    url: url,
    data: {
      'year': yearId
    },
    success: function (data) {
      $("#id_term").html(data);
    }
  });

});
  </script>

您包括了Vitor Freitas示例中的表单,但没有包括jquery脚本。如果您正确设置javascript,它将在年份下拉列表更改时运行,并发出ajax请求以更新术语下拉列表。如果没有它,术语下拉列表将不会更改,除非您刷新它,正如您所发现的那样。仔细阅读Vitor的代码,并将其更改为适合您的应用程序。如果您仍然有问题,请使用所有代码(包括javascript)更新您的问题,并描述您遇到的确切问题。