首页 > 解决方案 > 如何使用 html 表单更新基于 django 模型的表单(具有选择选项)记录

问题描述

我正在尝试更新我预先存在的模型**(ShiftChange)**,并以基于模型的形式使用了 CHOICES,如下所示。

 from django.db import models
        
     ======
=============
        )
        class ShiftChange(models.Model):
            ldap_id = models.CharField(max_length=64)
            Vendor_Company = models.CharField(max_length=64,choices=VENDOR_CHOICES,default='genesys')
            EmailID =  models.EmailField(max_length=64,unique=True)
            Shift_timing = models.CharField(max_length=64,choices=SHIFT_CHOICES,default='General_Shift')
            Reason = models.TextField(max_length=256)
            # updated_time = models.DateTimeField(auto_now=True)

并且要更新我正在使用基于 html 的表单,因为我想向最终用户显示内容(最终用户将单击更新按钮,如果他愿意,他可以通过选择下拉按钮来更改值)。我已经实现了创建、检索和删除视图,它工作正常,但更新操作不起作用。请找到我正在使用的 html 代码。 更新.html

<p>User information Update Form</p>
    <!--        <h5><span3>Note:</span3> For timing please use this format e.g 1.Morning Shift = <span2>6.30-3.30</span2> <br>2.Second Shift= <span1>3.30-12.30</span1><br>3.general Shift =<span4>9.00-6.00</span4></h5>-->
            <form method="post" class="post-form">
   
    
                {%csrf_token%}
    
                Ldap ID: <input type="text" name="ldap_id" value="{{oneuser.ldap_id}}"><br><br>
                Email ID: <input type="email" name="EmailID" value="{{oneuser.EmailID}}"><br><br>

                Company Name:<select name="Vendor_Company"
                <option value="{{oneuser.Vendor_Company}}">Genesys</option>
                <option value="{{oneuser.Vendor_Company}}">RMSI</option>
                <option value="{{oneuser.Vendor_Company}}">TCS</option>
                <option value="{{oneuser.Vendor_Company}}">Cognizant</option>
                <option value="{{oneuser.Vendor_Company}}">CTS</option></form></select>
                <br><br>
                Shift Timing:<select name="Shift_timing" choices=VENDOR_CHOICES

                <option value="{{oneuser.Shift_timing}}">9.00-6.00</option>
            <option value="{{oneuser.Shift_timing}}">6.30-3.30</option>
                <option value="{{oneuser.Shift_timing}}">12.30-3.30</option></div></select>
                <br><br>
    <!--            Shift Timing: <input type="text" name="Shift_timing" value="{{oneuser.Shift_timing}}"><br><br>-->
                Reason/justification for Change: <input type="textarea" name="Reason" value="{{oneuser.Reason}}"><br><br>
                <input type="submit" name="" value="Update Detail">
    
            </form>
        </div>
    </div>

当我将光标移到更新按钮上时,我可以看到它显示了正确的 url,但是在从下拉选项更改一些字段后单击提交时,它正在重定向到目标页面,但更改没有反映在 db 中。

我认为这个问题是因为在模型中实现了 CHOICES 选项,因为没有选择(下拉)它工作正常。

还想知道是否有任何方法可以通过使用基于模型的表单而不是 html 来完成此操作(但问题是如果我们使用模型表单如何显示内容)。

我的views.py代码

def update_view(request,id):
        oneuser=ShiftChange.objects.get(id=id)
        if request.method == "POST":
            form=ShiftChangeForm(request.POST,instance=oneuser)
            if form.is_valid():
                form.save(commit=True)
                return HttpResponseRedirect('/alldata')
        return render(request,'apple/update.html',{'oneuser':oneuser})

网址.py

url(r'^update/(?P<id>\d+)/$', views.update_view),

标签: htmlpython-3.xdjangodjango-formsdjango-templates

解决方案


你能通过这样做给网址命名吗:

url(r'^update/(?P<id>\d+)/$', views.update_view, name='update_shift'),

然后在您的模板中,您必须在表单标记的 action 属性中提供该 URL NAME,以便表单根据需要点击更新 url,如下所示:

<form method="post" class="post-form" action="{% url 'update_shift' oneuser.ldap_id %}">

然后您可以在视图中打印表单以查看如下内容:

print(form)

请参阅此 django 文档以在操作中提供表单 URL:

在这里,您可以执行保存。如果您不使用模型表单,则必须手动从表单中获取数据,然后像这样保存它。

并参考此 stackoverflow 以在不使用模型形式的情况下保存到 db


推荐阅读