所以我有一个名为Car
的模型,其外键为Manufacturer
模型。我还有一个CarCharacterisitcs
模型,其外键为Car
。
这就是代码的样子:
class Car(models.Model):
idcar = models.AutoField(primary_key=True)
manufacturer = models.ForeignKey(Manufacturer, null=True, blank=True, on_delete=models.SET_NULL)
name = models.CharField(max_length=765)
class Manufacturer(models.Model):
idmanufacturer = models.AutoField(primary_key=True)
name = models.CharField(max_length=765)
class CarCharacteristics(models.Model):
idcar_characteristics = models.AutoField(primary_key=True)
car = models.ForeignKey(Car, on_delete=models.PROTECT)
我正在制作一个页面,可让您添加CarCharacteristics
。
这是我的表格和观点:
class CarCharacteristicsForm(ModelForm):
class Meta:
model = CarCharacterisitics
def add_car_characteristics(request):
if request.method == 'POST':
car_char_form = CarCharacterisiticsForm(request.POST)
if car_char.is_valid(:
car_char_form.save()
return HttpResponseRedirect('/cars/car-characterisitcs')
else:
car_char_form = CarCharacterisiticsForm()
return render(request, 'car_characteristics/add_car_characteristics.html',{'car_char_form': car_char_form,})
在我的html页面中,我有这个:
<h1>Car Characteristics</h1>
<form action="." method="POST">
{% csrf_token %}
<table id="characteristics_table">
<tr>
<td>
<table id="car_characterisitcs_table">
<td>{{ char_char_form.as_table }}</td>
</table>
</td>
</tr>
</table>
<p><input type="submit" value="Submit"></p>
</form>
当显示此表单时,我有一个下拉选择字段,其中包含我所有可能的Car
模型。我想要的是有两个选择字段。我希望第一个让您能够选择Manufacturer
然后选择第二个来显示拥有该制造商的所有可能的Cars
。然后,当您提交表单时,它会将您选择的Car
分配给CarCharacterisitcs
模型的外键。
如果你去查看Advance Auto Parts,当你点击“你的车辆”时,这就是我想要的。我该怎么做?
答案 0 :(得分:0)
您需要使用AJAX获取所选制造商的数据并相应地填充汽车字段。这需要在视图代码中完成,并将汽车获取的数据返回到模板中,并使用模板语言填充该字段。