您好我正在尝试实现一个接受对象ID的编辑页面并加载其原始值&&启用编辑/更新。 例如
对于文本类型,我使用
<label>Field1:</label>
<input type="text" id="id_field1" value='{{ objectInstance.filed1}}' name="field1"/>
for Textares
<label>Field2:</label>
<textarea id="id_field2" name="field2">
{{ objectInstance.field2}}
他们都在加载实例的原始数据并允许编辑时工作得很好。但对于日期字段,我无法找到如何加载它.. 我正在尝试像
这样的东西<label>Deadline:</label>
<input type="date" id="id_deadline" name="deadline" value={{objectInstance.deadline}}>
(截止日期为日期数据类型,例如2013-6-4)
任何人都可以帮忙解决这个问题吗?非常感谢。
答案 0 :(得分:0)
您可以使用基于UpdateView
泛型类的视图来简化此过程。类似的问题是answered before。
解决此问题的另一种方法是使用ModelForm
,并使用实例预加载它。这实际上是UpdateView
的作用,但如果您不想使用基于类的视图,可以选择以下方法:
在forms.py
:
from django import forms
from someapp.models import SomeModel
class SomeModelForm(forms.ModelForm):
class Meta:
model = SomeModel
在views.py
:
def someview(request):
obj = SomeModel.objects.get(pk=1) # Fetch the object to be edited
form = SomeModelForm(instance=obj) # Load the form with the object's data
return render(request, 'edit.html', {'form': form})
在edit.html
:
<form method="POST">
{% csrf_token $}
{{ form }}
<input type="submit">
</form>
这将自动创建表单,并使用模型中的数据填充它。您仍然需要编写逻辑来更新视图中的记录。