[oldboy-django][2深入django]班级管理(Form)--查看
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">«</span></a></li>'
else:
prev_page = '<li><a href="%s?page=%s" aria-label="Previous"><span aria-hidden="true">«</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">»</span></a></li>'
else:
next_page = '<li><a href="%s?page=%s" aria-label="Next"><span aria-hidden="true">»</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)--查看的更多相关文章
- [oldboy-django][2深入django]班级管理(Form)--添加
1.需求: 添加班级,当有某个输入框数据格式不对时,会保留所有输入框的上次输入数据, 同时给出错误信息 2.视图 def add_class(request): # 提交数据都要用form来实现,因为 ...
- [oldboy-django][2深入django]班级管理(Form)--编辑
1.需求:编辑班级,难点:点击编辑按钮后,页面如何显示 待编辑 班级的信息(用Form实现), 以及Url 设置 2 url url(r'^edit_class/nid=(?P<nid>\ ...
- 【django小练习之主机管理界面】
需求: 利用django,js,bootstrap等实现登录,主机管理等操作. 实现截图 登录界面 主机界面,添加及编辑 部门管理界面 代码实现 目录层级 settings.py "&quo ...
- Django的Mov逻辑的管理特色
Django的MOV逻辑的管理特色 首先我们谈论到一个逻辑上的概念都从它的起点说起,在我看来mov的起点肯定就是Model了,那么Model有什莫特色呢 如果一个项目定义的Django那么Django ...
- 72、django之简单验证码实现与form表单钩子函数补充
本篇主要讲解简单的验证码实现,验证码使用基本都是找现成的组件来实现,用代码实现这个简单功能主要是了解了解验证码内部的实现. 本篇导航: 五位验证码图示 代码实现 登录验证 Form组件钩子函数补充 一 ...
- Python(Django)项目与Apache的管理
(开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...
- Python(Django)项目与Apache的管理交互
(开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...
- Django学习笔记(6)——Form表单
知识储备:HTML表单form学习 表单,在前端页面中属于最常见的一个东西了.基本上网站信息的提交都用到了表单,所以下面来学习Django中优雅的表单系统:Form 表单的主要作用是在网页上提供一个图 ...
- django中怎么使用自定义管理后台xadmin
django中怎么使用自定义管理后台xadmin 2018年05月19日 15:48:08 LH_python 阅读数:1001 首先创建基本的django项目,配置好基本的model ,url, ...
随机推荐
- 使用SAP云平台 + JNDI访问Internet Service
以Internet Service http://maps.googleapis.com/maps/api/distancematrix/xml?origins=Walldorf&destin ...
- IOS 当一个控件被添加到父控件中会调用(didMoveToSuperview)
/** * 当一个控件被添加到父控件中就会调用 */ - (void)didMoveToSuperview { if (self.group.opened) { self.nameView.image ...
- POJ 3041 Asteroids (对偶性,二分图匹配)
题目:POJ 3041 Asteroids http://poj.org/problem?id=3041 分析: 把位置下标看出一条边,这显然是一个二分图最小顶点覆盖的问题,Hungary就好. 挑战 ...
- 运维如何延续自己的职业生涯--萧田国2017年GOPS深圳站演讲内容
正如 萧田国在2017年GOPS深圳站演讲所提及的,运维职业生涯规划,应该是T字型. 关于指导原则,正如腾讯好友@赵建春所言: 如果一个领域不能做到TOP,那就是一种伤害. 运维在编程.开发领域,能做 ...
- 2018.7.1 css项目之模仿满屋花首页css+idv布局实现
可以分开写 <!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF ...
- Java面向对象之继承,方法重写,super关键字,员工类系列继承题
在程序中,如果想声明一个类继承另一个类,需要使用extends关键字. 格式: class 子类 extends 父类 {} 继承的好处 1.继承的出现提高了代码的复用性,提高软件开发效率. 2.继承 ...
- AJAX Control Toolkit的AsynFileUpload控件资料收集
基于AJAX的文件上传显示进度条实现 http://plkong.iteye.com/blog/238159 asp.net ajax AjaxFileUpload使用 多文件上传 http://bl ...
- 【Java】基本数据类型以及其转换
整理了一下Java基本数据类型和面试可能涉及的知识. 字节数(byte) 位数(bit) 取值范围 整型 byte 1 8 -2^7 ~ 2^7 -1 short 2 16 ...
- quartz调度
http://www.cnblogs.com/lzrabbit/archive/2012/04/14/2446942.html
- 爬虫 xpath etree自动补全页面
aa = etree.HTML(response.content) bb = etree.tostring(aa) doc = etree.HTML(bb)