1. 程式人生 > 程式設計 >django框架單表操作之增刪改例項分析

django框架單表操作之增刪改例項分析

本文例項講述了django框架單表操作之增刪改。分享給大家供大家參考,具體如下:

首先找到操作的首頁面

程式碼如下

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css" rel="external nofollow" >
  <title>書列表</title>
</head>
<body>
<div class="container">
  <a href="/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="/delete_book/?id={{ book.id }}" rel="external nofollow" class="btn btn-danger">刪除</a>
            <a href="/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 url
from django.contrib import admin
from app01 import views
urlpatterns = [
  # 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程式設計有所幫助。