我正在尝试修改数据库的一个现有行,它是一个来自名为“CharacterSkill”的中间表的行,具有唯一的together约束:
你知道吗型号.py你知道吗
class CharacterSkill(models.Model):
character = models.ForeignKey(Character, on_delete=models.CASCADE)
level = models.IntegerField(default=0)
skill = models.ForeignKey(Skill, on_delete=models.CASCADE)
class Meta:
unique_together = ("character","skill")
我做了一个表单来更改级别,但无法保存表单,两个字段“character”和“skill”都有两条错误消息:
Select a valid choice. That choice is not one of the available choices.
你能帮忙吗?:)
我的表格:
class SkillCreateForm(forms.ModelForm):
class Meta:
model = CharacterSkill
fields = ('skill','level','character',)
我的观点:
def skill_update(request,skillpk,instancepk):
form = SkillCreateForm(request.POST)
user = User.objects.get (id = request.user.id)
instance = Character.objects.get (id = instancepk)
skill = CharacterSkill.objects.get(id = skillpk)
data = {'character' : instance,
'skill' : skill.skill,
'level' : skill.level,
}
if form.is_valid():
form.save()
return redirect('persomaker:skill_list', instance.id)
else:
form = SkillCreateForm(data)
#form.fields['skill'].widget = HiddenInput()
#form.fields['character'].widget = HiddenInput()
return render(request, 'character/create_skill.html',
{'instance':instance,
'skill':skill,
'form': form,})
根据一本书,我改变了使用实例绑定窗体的方式:
相关问题 更多 >
编程相关推荐