如何在ListViewDjango中使用表单?

2024-09-30 16:24:21 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试为ListView创建一个操作,该操作将删除或更改模型中表中的参数,例如,禁用用户,使用复选框。 如果我选择了所有这些选项并单击此按钮,则会删除所有选定项。在

在**视图.py在

class AccountsManagementView(LoginRequiredMixin, generic.ListView):
    """
    Class Based View para a manipulação de usuários.
    """
    model = User
    template_name = 'accounts/accounts_management.html'
    context_object_name = 'users'


    def get_queryset(self):
        return User.objects.all()

class DeleteUser(DeleteView):
    model = User
    success_url = reverse_lazy('accounts:accounts_manager')

在**网址.py在

^{pr2}$

模板/帐户_管理.html在

<form action="" method="post">
<div class="panel panel-default">
    <div class="panel-heading">
        <div class="panel-title">
            <a href="{% url 'accounts:accounts_form' %}"><button type="button" class="btn btn-success mb_sm">
                <i class="fa fa-user-plus" aria-hidden="true" aria-hidden="true"></i> Add User
            </button></a>
            <button type="button" class="btn btn-danger mb_sm">
                <i class="fa fa-user-times" aria-hidden="true" aria-hidden="true"></i> Del User
            </button>
        </div>
    </div>
    <div class="panel-body">
        <div class="table-responsive">
                <table class="table table-striped" id="datatables__example">
                    <thead>
                    <tr>
                        <th scope="col" class="-colaction-checkboxumn">
                        <span>
                            <input type="checkbox" name="account-users" id="action-toggle" hidden="hidden"/>
                            <label for="action-toggle"></label>
                        </span>
                        </th>
                        <th>Foto</th>
                        <th>Nome</th>
                        <th>Usuário</th>
                        <th>Grupo</th>
                        <th>E-mail</th>
                        <th>Status</th>
                        <th>Ativo</th>
                        <th>Ações</th>
                    </tr>
                    </thead>
                    <tbody>
                    {% for usuario in users %}
                        <tr class="row1">
                            <td class="action-checkbox">
                                <input class="action-select" id="_selected_action" name="account-users" type="checkbox" value="{{ usuario.id }}" hidden="hidden"/>

                            </td>
                            <td scope="row">
                                <div class="sidebar-user__avatar">
                                    <img src="{{ usuario.imagem|thumbnail_url:'user_image' }}">
                                </div>
                            </td>
                            <td>
                                <a href="{{ usuario.get_absolute_url }}">{{ usuario.name }}</a>
                            </td>
                            <td>{{ usuario.username }}</td>
                            <td>{% if usuario.groups.all.0 %}
                                {{ usuario.groups.all.0 }}
                            {% else %}
                                <span>Não Atribuído</span>
                            {% endif %}</td>
                            <td>{{ usuario.email }}</td>
                            <td>
                                {% if usuario.is_authenticated %}
                                    <i class="fa fa-circle-o fa-lg" style="color: #4aa74e;" aria-hidden="true"></i> Online
                                {% else %}
                                    <i class="fa fa-circle-o fa-lg" style="color: #ac2925;" aria-hidden="true"></i> Offline
                                {% endif %}
                            </td>
                            <td>
                                {% if usuario.is_active == True %}
                                    {% comment %}<img src="{% static 'assets/ico/correct-45-45.png' %}">{% endcomment %}
                                    <a href="#" class="col-xs-1"> <i class="fa fa-check fa-lg" style="color: #4aa74e;" title="Desativar Conta"></i></a>
                                {% else %}
                                    {% comment %}<img src="{% static 'assets/ico/incorrect-45-45.png' %}">{% endcomment %}
                                    <a href="#" class="col-xs-1"> <i class="fa fa-ban fa-lg" style="color: #ac2925;" title="Ativar Conta"></i></a>
                                {% endif %}
                            </td>
                            <td>
                                <span>&nbsp;&nbsp;&nbsp;</span>

                                <a href="{% url 'accounts:accounts_edit' username=usuario.username %}"> <i class="fa fa-pencil fa-lg" style="color: #464960;" title="Editar Conta"></i></a>

                                <span>&nbsp;&nbsp;&nbsp;</span>

                                <a href="{{ usuario.get_absolute_url }}"> <i class="fa fa-eye fa-lg" style="color: #ec971f;" title="Visualizar Conta"></i></a>
                            </td>
                        </tr>
                    {% endfor %}
                    </tbody>
                </table>

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

Tags: divtrueurlbuttonactionhiddenclassfa
2条回答

你可以做的是让表单返回你想要删除的对象的pk列表。在

然后你做一些类似的事情:

def delete_view(request):
    if request.method == "post":
        data = [] # Array of pks
        User.objects.filter(pk__in=data).delete()

这应该能满足你的要求。在

如果这对你没有帮助的话,也许谷歌会批量删除django。似乎是以前存在的功能,但现在不再受支持。在

看看generic.UpdateView查看例如使用post()方法的CBV示例。在这里,您可以引入一个表单,验证输入,并处理—在您的情况下,查看每个复选框的值并相应地处理记录。在

您可能不需要像泛型视图那样将逻辑分解为多个方法,除非您希望使其可重用。在

相关问题 更多 >