UpdateView提供空白/空表单,而不是我编辑的先前数据

时间:2017-11-28 16:15:53

标签: python html mysql django web

我正在使用UpdateView使用表单编辑数据。

但是,当我单击编辑按钮时,表单为空白/空,没有以前的数据。

我甚至添加了{%with server.id as server_id%} {%with forms.id as edit_form%}  在我的index.html .. anoyone不知道我错过了什么吗?

view.py -

from django.shortcuts import render_to_response
from django.shortcuts import get_object_or_404
from django.shortcuts import render, redirect
from django.template import RequestContext
from django.views.generic import TemplateView, UpdateView, DeleteView, CreateView
from DevOpsWeb.forms import HomeForm
from DevOpsWeb.models import serverlist
from django.core.urlresolvers import reverse_lazy
from simple_search import search_filter
from django.db.models import Q
class HomeView(TemplateView):

    template_name = 'serverlist.html'


    def get(self, request):
        form = HomeForm()
    query = request.GET.get("q")
    posts = serverlist.objects.all()

    if query:
        posts = serverlist.objects.filter(Q(ServerName__icontains=query) | Q(Owner__icontains=query) | Q(Project__icontains=query) | Q(Description__icontains=query) | Q(IP__icontains=query) | Q(ILO__icontains=query) | Q(Rack__icontains=query))
    else:
        posts = serverlist.objects.all()
    args = {'form' : form, 'posts' : posts}
    return render(request, self.template_name, args)

def post(self,request):
    form = HomeForm(request.POST)
    posts = serverlist.objects.all()



    if form.is_valid(): # Checks if validation of the forms passed
        post = form.save(commit=False)
        #if not form.cleaned_data['ServerName']:
        #post.servername = " "
        post.save()
        #text = form.cleaned_data['ServerName']
        form = HomeForm()
        return redirect('serverlist')
args = {'form': form,  'text' : text}
return render(request, self.template_name,args)


class PostDelete(DeleteView):
    model = serverlist
    success_url = reverse_lazy('serverlist')

class PostEdit(UpdateView):
    model = serverlist
    #post = serverlist.objetcs.get(server_id=server_id)
    fields = ['ServerName','Owner','Project','Description','IP','ILO','Rack','Status']
    success_url=reverse_lazy('serverlist')

urls.py -

from django.conf.urls import url, include
from DevOpsWeb.views import HomeView
from DevOpsWeb.views import PostDelete
from DevOpsWeb.views import PostEdit
from django.contrib import admin
admin.autodiscover()

urlpatterns = [
    # Examples:
    url(r'^$', HomeView.as_view(), name='serverlist'),

     url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
     #DevOpsWeb:8000/Delete/
     url(r'^delete/(?P<pk>\d+)/$', PostDelete.as_view(), name="delete_post"),
     url(r'^django_popup_view_field/', include('django_popup_view_field.urls', namespace="django_popup_view_field")),
     url(r'^admin/', include(admin.site.urls)),
     #DevOpsWeb:8000/edit/
     url(r'^edit/(?P<pk>\d+)/$', PostEdit.as_view(), name="edit_post"),
]

forms.py -

from django import forms
from DevOpsWeb.models import serverlist


class HomeForm(forms.ModelForm):
    ServerName = forms.CharField(widget=forms.TextInput,max_length = 30,required=False)
    Owner = forms.CharField(max_length = 50,required=False)
    Project = forms.CharField(max_length = 30,required=False)
    Description = forms.CharField(max_length = 255,required=False)
    IP = forms.CharField(max_length = 30,required=False)
    ILO = forms.CharField(max_length = 30,required=False)
    Rack = forms.CharField(max_length = 30,required=False)
    Status = forms.CharField(max_length = 30,required=False)
    class Meta:
        model = serverlist
        fields = ('ServerName' ,'Owner','Project','Description','IP','ILO','Rack','Status',)

class AutoCompleteModelChoiceField(forms.ModelChoiceField):
    widget = forms.TextInput
def clean(self, value):
    value = super(AutoCompleteModelChoiceField, self).clean(value)
    return value


class serverForm(forms.ModelForm):
    hotel = AutoCompleteModelChoiceField(queryset=serverlist.objects.all())

index.html(带编辑按钮的部分) -

                {% for server in posts %}


        <tr>
          <div class ="server">
            <td></td>
            <td><center>{{ server.ServerName }}</center></td>
            <td><center>{{ server.Owner }}</center></td>
            <td><center>{{ server.Project }}</center></td>
            <td><center>{{ server.Description }}</center></td>
            <td><center>{{ server.IP }}</center></td>
            <td><center>{{ server.ILO }}</center></td>
            <td><center>{{ server.Rack }}</center></td>
            <td><h4><span class="badge badge-success">{{ server.Status }}</span></h4></td></center>

            <td>

&nbsp&nbsp&nbsp&nbsp
            <button type="button" class="btn btn-outline-danger" data-toggle="modal" href="#delete-server-{{server.id}}"
             data-target="#Del{{server.id}}">Delete <i class="fa fa-trash-o"></i></button>&nbsp
            <button type="button" class="btn btn-outline-primary" data-toggle="modal" href="#edit-server-{{server.id}}"
             data-target="#Edit{{server.id}}"> &nbsp&nbspEdit&nbsp           <i class="fa fa-pencil"></i></button>
&nbsp






                        <div id ="Del{{server.id}}" class="modal fade" role="document">
                            <div class="modal-dialog" id="delete-server-{{server.id}}">
                                    <div class="modal-content">
                                        <div class="modal-header">
                                            <h5 class="modal-title">Delete Confirmation</h5>
                                            <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                                <span aria-hidden="true">&times;</span>
                                    </button>
                                        </div>
                                        <div class="modal-body">
                                        <form action="{% url 'delete_post' server.id %}" method="post">{% csrf_token %}
                                            <h6>Are you sure you want to delete {{ server.ServerName }}?</h6>
                                                <br>
                                            <center><input type="submit" class="btn btn-danger btn-md" value="Confirm"/>
                                                <button type="submit" class="btn btn-secondary" data-dismiss="modal">Cancel</button></center>

                                        </form>
                                    </div>
                                    </div>


                        </div>
            </div>




            <div class="modal fade bd-example-modal-sm" id="Edit{{server.id}}" tabindex="-1" role="dialog" aria-labelledby="mySmallModalLabel" aria-hidden="true">
  <div class="modal-dialog modal-sm">
    <div class="modal-content">
                        <div class="modal-header">
                                <h5 class="modal-title">Edit Server <b>{{ server.ServerName }}</b> </h5>
                                <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                                        <span aria-hidden="true">&times;</span>
                                </button>
                        </div>
                                <div class="modal-body">

                                                                    {% with server.id as server_id %}
                                                                    {% with forms.id as edit_form %}

                                <form action="{% url 'edit_post' server_id %}" method="post"> {% csrf_token %}
                                    <!--<center>    {{ form.as_p }} </center> -->
                                    {% for field in form %}
                                        <div class="fieldWrapper">
                                            {{ field.errors }}
                                            <!-- {{ field.label_tag }} -->
                                            <small><b>{{ field.html_name }}<p align="left"></b> {{ field }}</small> </p>

                                            {% if field.help_text %}
                                                <p class="help">{{ field.help_text|safe }}</p>
                                            {% endif %}
                                      </div>
                                {% endfor %}
                            </div>
                            <div class="wrapper">
                            &nbsp&nbsp&nbsp&nbsp&nbsp&nbsp
                            <h2><button type="submit" class="save btn btn-success btn-lg">Confirm</button></h2>&nbsp&nbsp&nbsp
                                <h2><button type="submit" class="btn btn-secondary btn-lg" data-dismiss="modal">Cancel</button></h2>
                     </div>
                </form>
                {% endwith %}
                {% endwith %}
            </td>
                </div>
        </tr>
                {% endfor %}
    </tbody>
</h5>
    </table>

1 个答案:

答案 0 :(得分:1)

您的示例中存在一些问题。

首先,你没有复制状态。

现在,每次创建的每个表单的值都设置为None。这意味着您的输入将始终为空。您当前的方法确实需要替换form个实例并手动创建<input标记,或者在考虑modelforms paradigm时重新考虑。

其次,您没有有效的标记。

这将打破大多数浏览器。例如,你有

<small><b>{{ field.html_name }}<p align="left"></b> {{ field }}</small> </p>

这应该是:

 <small><b>{{ field.html_name }}</b></small> <p align="left">{{ field }} </p>

注意标签现在是如何平衡的?或者,甚至更好:

 <small>
   <strong>{{ field.html_name }}</strong>
 </small>
 <p align="left">{{ field }}</p>

现在您可以清楚地看到标签应该如何构建,从而更容易诊断任何问题。

第三,您使用的是过时的标签。

<center>自HTML 4以来一直不是有效节点。<b>不明智。请改用<strong>

第四,你的字符序列无效。

&nbsp&nbsp应为&nbsp;&nbsp;

最后,您还有遍布的调试代码。

与现有产品相比,这种方式很少,而且存在破坏性的风险:

<!--<center>    {{ form.as_p }} </center> -->