上一节我们完成了带分页的模糊查询,本节我们继续删除操作。

同样的,先给出各个模块的代码(上一节的就不在贴出了):
urls.py

    path('curd/delete/',views.curd_delete,name='curddelete'),
path('curd/deleteall/',views.curd_delete_all,name='curddeleteall')

views.py

def curd_delete(request):
#从前端(html)获取did数据
did=request.GET.get('did')
if did:
#找到该数据,将其删除
Book.objects.get(id=did).delete()
#删除成功,返回显示页
return redirect('/curd/') def curd_delete_all(request):
#先判断发过来的是否是post请求
if request.method=="POST":
#得到要删除的id列表
values=request.POST.getlist('vals')
for i in values:
#如果id不为空,获取该字段,并将其删除,我们只删除book表,publisher表不变
if i != '':
book_obj = Book.objects.get(id=i)
book_obj.delete()
#删除成功返回显示页
return redirect('/curd/')

curd.html

使用js前记得导入相应的文件,这里我使用的是百度源

<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<link rel="stylesheet" href="/static/bootstrap/css/bootstrap.css">
<script src="/static/bootstrap/js/bootstrap.js"></script>
<script type="text/javascript" src="http://libs.baidu.com/jquery/1.11.1/jquery.min.js"></script>
<script src="/static/js/curd.js"></script>
<style>
.myul li{
list-style: none;
margin-right: 4px;
margin-bottom: 4px;
float: left;
}
</style>
<title>Document</title>
</head>
<body>
<div style="width: 100%;">
<h3 align="center">书籍列表</h3>
<table class="table" style="table-layout: fixed;">
<div>
<div style="float: left">
<ul class='myul'>
<li><a onclick="getValues()" href="" class="btn btn-danger input-sm">批量删除</a></li>
<li><a href="" class="btn btn-info input-sm">添加</a></li>
</ul>
</div>
<div style="float: right">
<form method="get" action="" >
<input type="text" name="query"/>
<input type="submit" value="查询" name="submit" class="btn btn-primary input-sm"/>
</form>
</div>
</div>
<tr>
<th width=""><input type="checkbox" id="checkAll" onclick="checkAll()"></th>
<th>id</th>
<th>title</th>
<th>publisher</th>
<th>introduce</th>
<th>操作</th>
</tr>
<tr>
{% for item in page%}
<td><input type="checkbox" onclick="checkOne()" value="{{item.id}}" name="item"></td>
<td>{{item.id}}</td>
<td>{{item.title}}</td>
<td>{{item.publisher}}</td>
<td>{{item.introduce}}</td>
<td><a onclick="return confirm('确认要删除?')" class="btn btn-danger input-sm"
href="/curd/delete/?did={{item.id}}">删除</a></td>
</tr>
{% endfor %}
</table>
</div>
<!--底部分页按钮显示-->
<div style="position: absolute;top: 30 %;left: 44%">
<nav aria-label="Page navigation">
<div class="pagination">
<ul class="pagination" >
{% if page.has_previous %}
<li><a href="/curd/{{page.previous_page_number}}?query={{query}}" aria-label="Previous">
<span aria-hidden="true">&laquo;</span></a></li>
{% endif %} {% for num in page.paginator.page_range%}
{%if pindex == page.number%}
<li><a href="">{{ num }}</a></li>
{%else%}
<li><a href="/curd/{{num}}?query={{query}}">{{ num }}</a></li>
{%endif%}
{% endfor %} {% if page.has_next %}
<li><a href="{% url 'person:curdindex' page.next_page_number%}?query={{query}}" aria-label="Next">
<span aria-hidden="true">&raquo;</span></a></li>
{% endif %}
</ul>
</div>
</nav>
</div>
</body>
</html>

curd.js

function checkAll() {
var all = document.getElementById("checkAll"); if (all.checked == true) {
var ones = document.getElementsByName("item");
for (var i = 0; i <= ones.length; i++) {
ones[i].checked = true;
}
} else {
var ones = document.getElementsByName("item");
for (var i = 0; i <= ones.length; i++) {
ones[i].checked = false;
}
}
} function checkOne() {
var one=document.getElementsByName("item");
one.checked=true;
} function getValues() {
var valArr=[];
var ones=document.getElementsByName('item');
for (var i=0;i<ones.length;i++){
if (ones[i].checked==true){
valArr[i]=ones[i].value
}
}
if (valArr.length!=0){
// var vals = valArr.join(',');
// alert(valArr);
$.ajax({
       #地址一定要正确
url:"deleteall/",
       #全部大写
type:'POST',
contenType:'application/json',
       #不加这个,ajax会将结果后边加个[],例如{'vals[]':[4,6,8]}
traditional:true,
       #不加这个,会报服务器终止了一个在运行的程序
async: false,
data:{
'vals':valArr
},
success:function(){
alert("删除成功");
},
error:function(){
alert("删除失败");
}
})
}
else {
var error_m="请选择数据";
alert(error_m);
}
}

最后启动服务器:

我们跳转到最后一页,

点击删除:

点击确定。这一条数据就被删除了。总共就只有三页数据了,我们仍然跳转到最后一页:选择21,25,点击批量删除:(也可以点击id前面的多选框,实现全选)

具体流程:点击多选框--调用onclick中的函数(位于js)--得到要删除的id列表--将数据封装并通过ajax请求传给后端--后端接受请求并解析数据,对每一个id所在数据进行删除--删除成功返回显示界面。

删除成功后:

技术总结:一步一步的进行实现,首先是单条记录的删除,这还挺简单,将每条记录的id传给url地址,然后后台利用get请求获取即可。批量删除就比较麻烦了,从多选框的加入-->(全选和全不选-->部分选取(这两部分用js即可))-->如何将js中的值传给后端(利用ajax发送请求(期间也遇到不少问题))-->后端得到值并进行删除-->返回给前端。一步一步的走过来,总会遇到不少坑(我都会慢慢总结在另一篇博客《django勘误中》)。总而言之,遇到问题不要慌张,多百度,查找解决问题的方法,另外,有的问题或者方法不可能和自己的完全一样,要学会变通。

从html-css-js-ajax-django,学得越多,越是理解知识的界限是无穷的。

下一节:对数据进行编辑。

django实战(三)--删除和批量删除的更多相关文章

  1. 使用thinkPHP框架实现删除和批量删除一例【原创】

    本文为作者原创,转载请注明原作者及转载地址. 上一篇讲了如何用thinkPHP框架实现数据的添加,那这一篇就讲一下如何用thinkPHP实现数据的删除和批量删除吧. 预期效果图: 原谅博主对照片的处理 ...

  2. ajax 显示,删除,批量删除,修改反填功能实现

    1.页面代码 <body> <h1>显示所有员工信息</h1> <input id="Button1" type="button ...

  3. bootstrapTable--4.删除和批量删除

    http://blog.csdn.net/qq_26553781/article/details/78058389 ------------------------------------------ ...

  4. oss文件上传删除(批量删除)处理

    博主用的是阿里云的oss 首先先在阿里云下载安装sdk,相关的sdk下载请自行到阿里云下载 文档地址   https://help.aliyun.com/document_detail/85580.h ...

  5. jdbc-批量插入、批量删除、批量更新

    一.JDBC的批量插入 JDBC批量插入主要用于数据导入和日志记录因为日志一般都是先写在文件下的等.    我用Mysql5.1.5的JDBC driver 分别对三种比较常用的方法做了测试   方法 ...

  6. mteclipse中运行的分页,搜索,列表批量删除的界面,它的源代码

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <hea ...

  7. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(18)-过滤器的使用和批量删除数据(伪删除和直接删除)

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(18)-过滤器的使用和批量删除数据(伪删除和直接删除) ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   ...

  8. 5月21 汽车查询及批量删除----php方法

    ---恢复内容开始--- 这个与之前不同是在php中实现了页面的查询,引用AJAX实现批量删除及弹窗的显示 作业要求: 页面显示数据代码: <!DOCTYPE html PUBLIC " ...

  9. sql server中的大数据的批量操作(批量插入,批量删除)

    首先我们建立一个测试用员工表 ---创建一个测试的员工表--- create table Employee( EmployeeNo int primary key, --员工编号 EmployeeNa ...

随机推荐

  1. django中视图函数中装饰器

    方法一 给指定方法加 from django.utils.decorators import method_decorator class xx(View): @method_decorator(装饰 ...

  2. tf.where()函数的解析

    tf.where()的使用,该函数会返回满足条件的索引.经验证,发现返回均是二维矩阵,可以说明该函数用二维矩阵给出满足条件的位置索引.(若有错误,欢迎指正.) 代码如下:import tensorfl ...

  3. Java之路---Day16(泛型)

    2019-11-02-23:25:26 目录 1.泛型的概念: 2.泛型的定义和使用: 2.1定义和使用含有泛型的类: 2.2定义和使用含有泛型的方法: 2.3定义和使用含有泛型的接口: 泛型的概念: ...

  4. GALAXY OJ NOIP2019联合测试1-总结

    概要 本次比赛考的不是很好,400分的题只拿了180分...(失误失误) 题目 T1:数你太美(预期100 实际60) 题目大意: 在两个序列中找两个最小的数进行组合,使这个最小整数最小. 解析: 只 ...

  5. Eureka获取服务列表源码解析

    在之前的文章:EurekaClient自动装配及启动流程解析中,我们提到了在类DiscoveryClient的构造方法中存在一个刷新线程和从服务端拉取注册信息的操作 这两个就是eureka获取服务列表 ...

  6. 怎么进入bios设置界面,电脑如何进入BIOS进行设置,怎么进入BIOS的方法集合

    怎么进入bios设置界面,电脑如何进入BIOS进行设置,怎么进入BIOS的方法集合 开机出现电脑商家图标时,按住F10键进入BIOS界面.进入BIOS界面一般都是开机后按<del,Esc,F1, ...

  7. Objective-C学习——中文URL编码和解码

    发现NSString类中有内置的方法可以实现.他们分别是: - (NSString *)stringByAddingPercentEscapesUsingEncoding:(NSStringEncod ...

  8. 对cell每一行做标记

    通过数组进行标记 初始化列表的时候给一个值如 for (int i = 0; i < [self.tableData count]; i++)    {        [_allOrderBoo ...

  9. Google Analytics 学习笔记四 —— GA的Channels划分规则

    一.流量的Source.Medium和Campaigns 1.Source Source或traffic source通常表示流量的来源,一般通过urm_source参数跟踪 在GA中,流量来源的名字 ...

  10. vue全家桶项目应用断断续续的记录

    一.引用axios插件报错 axios使用文档 Cannot read property 'protocol' of undefined 解决方法:在mainjs文件中把axios引入vue的原型函数 ...