Jquery django-动态字段-错误:选择有效选项。该选择不是可用的选择之一

Jquery django-动态字段-错误:选择有效选项。该选择不是可用的选择之一,jquery,ajax,django,django-forms,Jquery,Ajax,Django,Django Forms,我有以下几种型号 class Category(MPTTModel): name=models.CharField(max_length=75,null=False,blank=False, unique=True) parent=TreeForeignKey('self', null=True, blank=True, related_name='children', db_index=True) class ProductGroup(models.Model): n

我有以下几种型号

class Category(MPTTModel):
    name=models.CharField(max_length=75,null=False,blank=False, unique=True)
    parent=TreeForeignKey('self', null=True, blank=True, related_name='children', db_index=True)

class ProductGroup(models.Model):
    name = models.CharField(max_length=30,null=False, blank=False)
    category=TreeForeignKey('category.Category', null=False,blank=False)

class Product(models.Model):
    product_group=models.ForeignKey('productgroup.ProductGroup', null=False,blank=False)
    manufacturer=models.ForeignKey(Manufacturer, null=False,blank=False)
    product_type=models.CharField(max_length=2, choices=PRODUCT_TYPE,)
    opening_stock=models.PositiveIntegerField(default=0)
这是我的观点和形式

class CreateProduct(CreateView):
    model=Product
    form_class=ProductForm

class ProductForm(forms.ModelForm):
        def __init__(self, *args, **kwargs):
            user = kwargs.pop('user','')
            super(ProductForm, self).__init__(*args, **kwargs)
            self.fields['category']=TreeNodeChoiceField(queryset=Category.objects.all())
            self.fields['category'].required = False
            self.fields['product_group']=forms.ModelChoiceField(queryset=ProductGroup.objects.none())
            original_fields = self.fields

            new_order = OrderedDict()
            for key in ['category','product_group', 'manufacturer', 'product_type', 'wheel_position', 'opening_stock']:
                new_order[key] = original_fields[key]
            self.fields = new_order
        class Meta:
            model = Product     
            fields=['product_group', 'manufacturer', 'product_type', 'wheel_position', 'opening_stock']
GetProductGroups Ajax视图

def GetProductGroups(request):
    product_groups=ProductGroup.objects.filter(category__id=request.GET.get('id'))
    to_json = []
    for pg in product_groups:
        # for each object, construct a dictionary containing the data you wish to return
        mydict = {}
        mydict['id'] = pg.id
        mydict['name'] = pg.name
        to_json.append(mydict)

    response_data = json.dumps(to_json)

    return HttpResponse(response_data, content_type="application/json") 
jquery在product_form.html中的ajax查询

<script>
$("#id_category").change(function () {
  var category = $(this).val();
  $.ajax({
    method:'get',
    url: '/ajax/get_product_groups/',
    data: {
      'id': category
    },
    dataType: 'json',
    success: function (data) {

        $('#id_product_group').empty()
        $('#id_product_group').append(
                 $('<option></option>').val(0).html('------------')
             );
        $.each(data, function(key, value){
            $('#id_product_group').append(
                 $('<option></option>').val(value.id).html(value.name)
             );
        });
    }
  });

});
</script>
jquery脚本完美地获取了类别选择的数据,但是当按下submit按钮时,我得到了以下验证错误-跨产品组字段

选择一个有效的选项。这一选择不是可用的选择之一 选择

..相应的下拉列表也被清空

谁能告诉我我的代码有什么问题吗

谢谢


我不知道如何将新创建的字段与现有字段连接起来<代码>过滤器(category=self.data.get('category'))成功了

self.fields['product_group']=forms.ModelChoiceField(queryset=ProductGroup.objects.filter(category=self.data.get('category')))
self.fields['product_group']=forms.ModelChoiceField(queryset=ProductGroup.objects.filter(category=self.data.get('category')))