1 需求:django实现班级管理:查看(分页); 数据库采用django自带的sqlite3

2 数据库表创建

from django.db import models

class Classes(models.Model):
title = models.CharField(max_length=64) class Student(models.Model):
name = models.CharField(max_length=64)
age = models.IntegerField()
email = models.EmailField()
cls = models.ForeignKey('Classes') class Teacher(models.Model):
name = models.CharField(max_length=64)
age = models.IntegerField()
email = models.EmailField()
cls = models.ManyToManyField('Classes')

执行python manage.py makemigrations, python manage.py migrate使得数据库表创建生效

3 视图设计

# -*- coding: utf-8 -*-
from django.shortcuts import render, redirect
from app01 import models
from django.forms import Form, fields class ClassForm(Form):
title = fields.RegexField("^全栈\w+") def classes(request):
from utils.pagation_define import PageInfo
current_page_number = request.GET.get('page')
all_count = models.Classes.objects.all().count()
page_info = PageInfo(current_page_number, all_count, "/app01/classes")
class_list = models.Classes.objects.all()[page_info.start():page_info.end()]
# 列表切片操作 a[start:end] start<= index < end
return render(request, 'app01_class_list.html', {'class_list': class_list, 'page_info': page_info})

4 模板设计

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link rel="stylesheet" href="/static/plugins/bootstrap-3.3.7-dist/css/bootstrap.css">
<link rel="stylesheet" href="/static/plugins/font-awesome-4.7.0/css/font-awesome.css">
</head>
<body>
<h4>班级管理</h4>
<p>
<a href="/app01/add_class" class="btn btn-primary">添加</a>
</p>
<table class="table table-striped table-bordered table-hover table-condensed">
<thead>
<tr>
<th>班级ID</th>
<th>班级名称</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for item in class_list %}
<tr>
<td>{{ item.id }}</td>
<td>{{ item.title }}</td>
<td>
<a href="/app01/edit_class/nid={{ item.id }}" class="glyphicon glyphicon-pencil">编辑</a>|
<a href="/app01/del_class/nid={{ item.id }}" class="glyphicon glyphicon-trash">删除</a>
</td>
{#点击删除是一个get请求,要想告诉服务器id,可以通过url get请求获取,或者url匹配到传递给视图#}
</tr>
{% endfor %} </tbody>
</table>
<nav aria-label="Page navigation">
<ul class="pagination">
{{ page_info.pager|safe }}
</ul>
</nav>
</body>
</html>

5 补充分页模块

class PageInfo(object):
def __init__(self, current_page_num, all_count, base_url, per_page=10, show_page=11):
try:
self.current_page_num = int(current_page_num)
except Exception as e:
self.current_page_num = 1
self.per_page = per_page
a,b = divmod(all_count, per_page)
if b:
a = a + 1 self.all_page = a
self.show_page = show_page
self.base_url = base_url def start(self):
return (self.current_page_num - 1) * self.per_page def end(self):
return self.current_page_num * self.per_page def pager(self): page_list = []
# 如果总的页码数小于11
if self.show_page >= self.all_page:
begin = 1
stop = self.all_page
# 总页码数大于11
else:
half,_ = divmod(self.show_page,2)
if self.current_page_num <= half:
begin = 1
stop = self.show_page
else:
temp = self.all_page - half
if self.current_page_num >= temp:
begin = self.all_page - self.show_page + 1
stop = self.all_page
else:
begin = self.current_page_num - half
stop = self.current_page_num + half prev_page = ''
if self.current_page_num == 1:
prev_page = '<li class="disabled"><a aria-label="Previous"><span aria-hidden="true">&laquo;</span></a></li>'
else:
prev_page = '<li><a href="%s?page=%s" aria-label="Previous"><span aria-hidden="true">&laquo;</span></a></li>'% (self.base_url, self.current_page_num -1)
page_list.append(prev_page)
for i in range(begin, stop + 1):
if i == self.current_page_num:
temp = '<li class="active"><a href="%s?page=%s">%s</a></li>' % (self.base_url, i,i)
else:
temp = '<li><a href="%s?page=%s">%s</a></li>' % (self.base_url,i,i)
page_list.append(temp) next_page= ''
if self.current_page_num == self.all_page:
next_page = '<li class="disabled"><a aria-label="Next"><span aria-hidden="true">&raquo;</span></a></li>'
else:
next_page = '<li><a href="%s?page=%s" aria-label="Next"><span aria-hidden="true">&raquo;</span></a></li>' % (self.base_url,self.current_page_num +1)
page_list.append(next_page)
return ''.join(page_list)

  

[oldboy-django][2深入django]班级管理(Form)--查看的更多相关文章

  1. [oldboy-django][2深入django]班级管理(Form)--添加

    1.需求: 添加班级,当有某个输入框数据格式不对时,会保留所有输入框的上次输入数据, 同时给出错误信息 2.视图 def add_class(request): # 提交数据都要用form来实现,因为 ...

  2. [oldboy-django][2深入django]班级管理(Form)--编辑

    1.需求:编辑班级,难点:点击编辑按钮后,页面如何显示 待编辑 班级的信息(用Form实现), 以及Url 设置 2 url url(r'^edit_class/nid=(?P<nid>\ ...

  3. 【django小练习之主机管理界面】

    需求: 利用django,js,bootstrap等实现登录,主机管理等操作. 实现截图 登录界面 主机界面,添加及编辑 部门管理界面 代码实现 目录层级 settings.py "&quo ...

  4. Django的Mov逻辑的管理特色

    Django的MOV逻辑的管理特色 首先我们谈论到一个逻辑上的概念都从它的起点说起,在我看来mov的起点肯定就是Model了,那么Model有什莫特色呢 如果一个项目定义的Django那么Django ...

  5. 72、django之简单验证码实现与form表单钩子函数补充

    本篇主要讲解简单的验证码实现,验证码使用基本都是找现成的组件来实现,用代码实现这个简单功能主要是了解了解验证码内部的实现. 本篇导航: 五位验证码图示 代码实现 登录验证 Form组件钩子函数补充 一 ...

  6. Python(Django)项目与Apache的管理

    (开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...

  7. Python(Django)项目与Apache的管理交互

    (开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...

  8. Django学习笔记(6)——Form表单

    知识储备:HTML表单form学习 表单,在前端页面中属于最常见的一个东西了.基本上网站信息的提交都用到了表单,所以下面来学习Django中优雅的表单系统:Form 表单的主要作用是在网页上提供一个图 ...

  9. django中怎么使用自定义管理后台xadmin

    django中怎么使用自定义管理后台xadmin 2018年05月19日 15:48:08 LH_python 阅读数:1001   首先创建基本的django项目,配置好基本的model ,url, ...

随机推荐

  1. 为OSSIM添加 ossec的linux agent

    1,安装环境 [root@node32 test]# yum groupinstall "Development Tools" -y Installed: byacc.x86_64 ...

  2. 工作流性能优化(敢问activiti有扩展性?)(2)

    2015/4/17 粗略看了activiti的sql的,在ativity engine包里边: 没什么头绪,先用excel记录数据量少的时候本机的性能情况:   不打印hibernate的sql:一刷 ...

  3. 国外常用代理IP对比【仅供参考】

    国外常用代理IP对比[仅供参考]http://www.it588.cn/vmware/2019-03-22/547.html

  4. animation写动画

    最近,接到项目需求,需要写大量的动画,那么怎么写呢? 动画是使元素从一种样式逐渐变化为另一种样式的效果.可以用百分比来规定变化发生的时间,或用关键词 "from" 和 " ...

  5. x5webview 微信H5支付

    mWebView.setWebViewClient(new WebViewClient() { // @Override // public boolean shouldOverrideUrlLoad ...

  6. ubuntu jdk install

    1.下载jdk-7u75-linux-x64.tar.gz,默认在/home/csf/Downloads 2.csf@ubuntu:~/Downloads$ sudo mkdir /usr/java ...

  7. 高阶函数 -------JavaScript

    高阶函数 本文摘要:http://www.liaoxuefeng.com/ JavaScript的函数其实都指向某个变量.既然变量可以指向函数,函数的参数能接收变量,那么一个函数就可以接收另一个函数作 ...

  8. ES6 Proxy拦截器详解

    Proxy 拦截器 如有错误,麻烦指正,共同学习 Proxy的原意是"拦截",可以理解为对目标对象的访问和操作之前进行一次拦截.提供了这种机制,所以可以对目标对象进行修改和过滤的操 ...

  9. react的constructor和super的具体含义和使用

    1.constructor( )-----super( )的基本含义 这是ES6对类的默认方法,通过 new 命令生成对象实例时自动调用该方法.并且,该方法是类中必须有的,如果没有显示定义,则会默认添 ...

  10. 1074: [SCOI2007]折纸origami

    Time Limit: 20 Sec  Memory Limit: 162 MBSubmit: 372  Solved: 229[Submit][Status][Discuss] Descriptio ...