django框架单表操作之增删改实例分析
框架(架构)  /  管理员 发布于 7年前   199
本文实例讲述了django框架单表操作之增删改。分享给大家供大家参考,具体如下:
首先找到操作的首页面
代码如下
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <link rel="stylesheet" href="https:static/bootstrap/css/bootstrap.min.css" rel="external nofollow" > <title>书列表</title></head><body><div class="container"> <a href="https:add_book/" rel="external nofollow" class="btn btn-success">添加新书</a> <div class="panel panel-primary"> <div class="panel-heading">书籍管理</div> <div class="panel-body"> <table class="table table-bordered table-striped"> <thead> <tr> <th>#</th> <th>书名</th> <th>操作</th> </tr> </thead> <tbody> {% for book in book_list %} <tr data-id="{{ book.id }}"><td>{{ forloop.counter }}</td><td>{{ book.title }}</td><td><a href="https:delete_book/?id={{ book.id }}" rel="external nofollow" class="btn btn-danger">删除</a><a href="https:edit_book/?id={{ book.id }}" rel="external nofollow" class="btn btn-info">修改</a></td> 此处的?id可以改成 ?iid,或者其他的名称,在views.py文件里对函数edit_book修改即可edit_id=request.GET.get('iid') </tr> {% endfor %} </tbody> </table> </div> </div> </div> </body> </html>
主页:
之后,根据不同的操作指向不同的页面,这部分功能需要修改urls.py
from django.conf.urls import urlfrom django.contrib import adminfrom app01 import viewsurlpatterns = [ # url(r'^admin/', admin.site.urls), url(r'^home/',views.home), url(r'^index/',views.index), url(r'^login/',views.login), url(r'^book_list/',views.book_list), #添加新书 url('^add_book/',views.add_book), #删除书籍 url('^delete_book/',views.delete_book), #修改书籍 url(r'^edit_book/',views.edit_book),]
其次,不同操作指向不同的页面
add_book.html
主要的部分
<form class="form-horizontal" action="/add_book/" method="post"> #提交到 add_book <div class="form-group"><label for="inputbookname" class="col-sm-2 control-label">书籍名称</label><div class="col-sm-3"> <input type="text" class="form-control" id="inputbookname" name="book_name"> </div> </div> <div class="form-group"><div class="col-sm-offset-2 col-sm-10"> <button type="submit" class="btn btn-default">添加新书</button>
edit_book.html
主要部分
<form class="form-horizontal" action="/edit_book/" method="post"> <input hidden type="text" name="book_id" value="{{ book.id }}"> <div class="form-group"> <label for="inputbookname" class="col-sm-2 control-label">书籍名称</label> <div class="col-sm-3"> <input type="text" class="form-control" id="inputbookname" name="book_name" value="{{ book.title }}"> </div> </div> <div class="form-group"> <div class="col-sm-offset-2 col-sm-10"> <button type="submit" class="btn btn-default">提交修改</button>
删除在后台执行
最后后台函数的配置views.py
def book_list(request): #找到所有的书 books=models.Book.objects.all() return render(request,"book_list.html",{"book_list":books})def add_book(request): #判断是否为post if request.method=="POST": new_book_name=request.POST.get("book_name") #去数据库创建一条记录 models.Book.objects.create(title=new_book_name) #跳转回之前书籍展示的页面 return redirect("/book_list/") #返回一个页面让用户填写新书的相关信息 return render(request,"add_book.html")def delete_book(request): #取到要删除书的id,如何从get请求获取数据 delete_id=request.GET.get("id") #根据id值去数据库取对应的数据 models.Book.objects.get(id=delete_id).delete() return redirect("/book_list/")def edit_book(request): if request.method=="POST": #取到书的id book_id=request.POST.get("book_id") #用户修改后的名称 new_book_title=request.POST.get("book_name") #在数据库中查找id对应的记录 book_obj= models.Book.objects.get(id=book_id) #将用户的名称给修改到这个id中 book_obj.title=new_book_title #保存提交 book_obj.save() #跳转到书列表的页面 return redirect("/book_list/") edit_id=request.GET.get('id') book=models.Book.objects.get(id=edit_id) return render(request,"edit_book.html",{"book":book}) #以字典的方式传递变量#note:# 对书籍进行编辑,是通过book_list页面传递id(或者iid),在对上面的函数获取其id时得到edit_id,知道其id和title就可以进行修改
希望本文所述对大家基于Django框架的Python程序设计有所帮助。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号