Django 中实现批量删除确认提示

心靈之曲
发布: 2025-08-03 22:22:19
原创
530人浏览过

django 中实现批量删除确认提示

本文介绍了如何在 Django 项目中,针对通过复选框选择的多个数据进行批量删除操作时,添加用户确认提示。通过 JavaScript 的 confirm() 方法,在用户点击删除按钮后弹出确认对话框,避免误操作导致的数据丢失,从而提升用户体验。

在 Django 项目中,实现批量删除功能时,为了防止用户误操作,通常需要在删除前添加一个确认提示。以下介绍如何利用 JavaScript 的 confirm() 函数实现这一功能。

实现步骤:

  1. 修改 HTML 模板:

在 HTML 模板中,找到批量删除按钮,并添加一个 onclick 事件处理程序。该事件处理程序会调用 confirm() 函数,根据用户的选择决定是否提交表单。

   <form method="post" id="deleteForm">
       {% csrf_token %}
       <table class="table table-success table-striped" id="table">
           <thead>
               <th>#</th>
               <th>Assignments</th>
               <th>Amount</th>
               <th>Date</th>
               <th>
                   <button class="btn btn-danger btn-sm" name="delete_all" onclick="return confirmDelete()">Delete selected</button>
               </th>
           </thead>
           <tbody>
               {% for info in data %}
               <tr>
                   <td><input type="checkbox" name="x[]" value="{{info.id}}"> {{forloop.counter}}</td>
                   <td>{{info.assignment}}</td>
                   <td>{{info.amount}}</td>
                   <td>{{info.add_date}}</td>
                   <td>
                       <a class="btn btn-danger btn-sm" href="{% url 'expens_delete' info.id %}"><i class="bi bi-x"></i></a>
                       <a class="btn btn-warning btn-sm" href="{% url 'expens_edit' info.id %}"><i class="bi bi-pencil"></i></a>
                   </td>
               </tr>
               {% endfor %}
           </tbody>
       </table>
   </form>
登录后复制
  1. 添加 JavaScript 代码:

在 HTML 模板的 <script> 标签中,添加以下 JavaScript 代码。该代码定义了一个名为 confirmDelete() 的函数,该函数会弹出一个确认对话框,询问用户是否确定删除。如果用户点击“确定”按钮,则返回 true,表单将被提交;否则,返回 false,表单不会被提交。

   <script>
       function confirmDelete() {
           return confirm("确定要删除选中的数据吗?");
       }
   </script>
登录后复制
  1. 修改 views.py:

保持原有的逻辑不变。

图可丽批量抠图
图可丽批量抠图

用AI技术提高数据生产力,让美好事物更容易被发现

图可丽批量抠图 26
查看详情 图可丽批量抠图
   def expens(request):
       data = ''
       number = ''

       if 'delete_all' in request.POST:
           choosen = request.POST.getlist('x[]')
           if choosen:
               for selected in choosen:
                   picked = Expenses.objects.filter(id=selected)
                   picked.delete()
               messages.info(
                   request, "Expens data has been deleted successfully.", extra_tags='success')
           else:
               messages.info(request, "Please select to delete.",
                             extra_tags='error')

       if 'save' in request.POST:
           pass  # Handle save logic if needed

       return render(request, 'expens.html', {'data': data, 'number': number})
登录后复制

完整示例代码:

{% extends 'base.html' %}

{% block content %}
<form method="post" id="deleteForm">
    {% csrf_token %}
    <table class="table table-success table-striped" id="table">
        <thead>
            <th>#</th>
            <th>Assignments</th>
            <th>Amount</th>
            <th>Date</th>
            <th>
                <button class="btn btn-danger btn-sm" name="delete_all" onclick="return confirmDelete()">Delete
                    selected</button>
            </th>
        </thead>
        <tbody>
            {% for info in data %}
            <tr>
                <td><input type="checkbox" name="x[]" value="{{info.id}}"> {{forloop.counter}}</td>
                <td>{{info.assignment}}</td>
                <td>{{info.amount}}</td>
                <td>{{info.add_date}}</td>
                <td>
                    <a class="btn btn-danger btn-sm" href="{% url 'expens_delete' info.id %}"><i
                            class="bi bi-x"></i></a>
                    <a class="btn btn-warning btn-sm" href="{% url 'expens_edit' info.id %}"><i
                            class="bi bi-pencil"></i></a>
                </td>
            </tr>
            {% endfor %}
        </tbody>
    </table>
</form>

<script>
    function confirmDelete() {
        return confirm("确定要删除选中的数据吗?");
    }
</script>
{% endblock %}
登录后复制

注意事项:

  • 确保在 HTML 模板中正确引入了 JavaScript 代码。
  • 可以根据实际需求自定义确认对话框的内容。
  • 如果需要更复杂的确认提示,例如自定义样式的模态框,可以使用 JavaScript 库(如 Bootstrap Modal)来实现。
  • confirm() 函数是浏览器提供的内置函数,因此无需额外安装任何依赖。

总结:

通过以上步骤,可以在 Django 项目中轻松实现批量删除确认提示功能,有效地防止用户误操作,提升用户体验。这种方法简单易用,无需引入额外的依赖,适用于大多数 Django 项目。

以上就是Django 中实现批量删除确认提示的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号