一、使用django实现之定义分页

1、自定义分页在django模板语言中,通过a标签实现;

2、前段a标签使用<a href="/user_list/?page=1">1</a>,将page的值传送到函数/user_list/中,后端在user_list中通过request.GET.get('page',1)获取当前页;

3、从数据库中获取特定行的数据,使用result = models.UserList.objects.all()[start:end]获取,start和end分别表示开始和结束的行;

3、自定义分页显示到模板语言中的html/css/js的字符串,在django view中,通过python字符串拼接生成;

4、获取分页的起始页,结束页,以及当前页居中等功能,抽象出来,放到一个类中实现;

5、Django默认认为返回给前段的字符串是不安全的(XSS),所有直接返回的html中,会显示为原始的字符串,可以通过在前段使用|safe或者在后端使用后make_safe实现将字符串能够让浏览器进行解析;

6、分页优化需要考虑:让当前页居中,增加上一页和下一页功能;

#-*- coding:utf- -*-
from django.shortcuts import render
from app01 import models
from django.utils.safestring import mark_safe # Create your views here. class Pager(object):
def __init__(self,current_page):
self.current_page = int(current_page)
@property
def start(self):
return (self.current_page -)* @property
def end(self):
return self.current_page* def page_str(self,all_item,base_url):
all_page,div = divmod(all_item,)
if div>:
all_page+= pager_list = [] if all_page <=: #分页功能优化,将当前页居中,并且从1开始
start =
end = all_page
else:
if self.current_page <=:
start =
end =
else:
start = self.current_page-
end = self.current_page +
if self.current_page + >all_page:
start =all_page -
end = all_page +
for i in range(start,end): #让当前页永远居中
if i == self.current_page:
temp = '<a style="color:red;font-size:26px;" href="%s%d">%d</a>' %(base_url,i,i)
else:
temp = '<a href="%s%d">%d</a>' %(base_url,i,i)
pager_list.append(temp) #增加上一页和下一页功能
#上一页
if self.current_page >:
pre_page = '<a href="%s%d">上一页</a>' %(base_url,self.current_page-)
else:
pre_page = '<a href="javascript:void(0);">上一页</a>' if self.current_page >=all_page:
next_page = '<a href="javascript:void(0);">下一页</a>'
else:
next_page = '<a href="%s%d">下一页</a>' %(base_url,self.current_page+)
pager_list.insert(,pre_page)
pager_list.append(next_page)
return mark_safe("".join(pager_list)) #在后端标记html是安全的,前端标记为安全的使用page_str|safe def user_list(request):
# for item in range(,):
# temp = {'username':"name %d" %item,'age':item}
# models.UserList.objects.create(**temp)
print models.UserList.objects.all().count()
#每页显示10条
#向用户显示页数
current_page = request.GET.get('page',)
# print current_page
# current_page = int(current_page)
# start = (current_page-)*
# end = current_page*
# result = models.UserList.objects.all()[start:end]
page_obj = Pager(current_page)
result = models.UserList.objects.all()[page_obj.start:page_obj.end]
print result.query #对应的sql语句
all_item = models.UserList.objects.all().count()
# all_page,div = divmod(all_item,)
# if div>:
# all_page+=
#
# pager_str = ""
# for i in range(,all_page+):
# temp = '<a href="/user_list/?page=%d">%d</a>' %(i,i)
# pager_str +=temp
pager_str = page_obj.page_str(all_item,"/user_list/?page=")
return render(request,'user_list.html',{'result':result,'pager_str':pager_str})

模板语言文件

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
a{
padding: 5px;
}
</style>
</head>
<body>
<table>
{% for line in result %}
<tr>
<td>{{ line.username }}</td>
<td>{{ line.age }}</td>
</tr>
{% endfor %}
</table> <div>
{# <a href="/user_list/?page=1"></a>#}
{# <a href="/user_list/?page=2"></a>#}
{# <a href="/user_list/?page=3"></a>#}
{# <a href="/user_list/?page=4"></a>#}
{# {{ pager_str|safe }}#}
{{ pager_str }}
{# 一般对于返回到网页的字符串,django认为是不安全的,为了防止xss攻击,会将返回的字符串不作解析,以原始字符串的格式返回,使用safe表示我们认为返回的字符串是安全的,可以被浏览器解析#}
</div>
</body>
</html>

二、Bottle

1、只有一个文件,但是至少依赖于两个部件:wsgi和模板引擎;

2、只有在运行时依赖别的模块;

bottle路由系统查看银角大王博客

三、Flask

Flask有很多现成的插件可以使用,但是没有自己的模板引擎和wsgi,需要依赖于其他的模本引擎;

四、Tarnado

支持异步非阻塞,见下图

五、自定义Form表单

#!/usr/bin/env python
# -*- coding:utf- -*- import tornado.ioloop
import tornado.web
from hashlib import sha1
import os, time
import re class MainForm(object):
def __init__(self):
self.host = "(.*)"
self.ip = "^(25[0-5]|2[0-4]\d|[0-1]?\d?\d)(\.(25[0-5]|2[0-4]\d|[0-1]?\d?\d)){3}$"
self.port = '(\d+)'
self.phone = '^1[3|4|5|8][0-9]\d{8}$' def check_valid(self, request):
#request,用户提交的表单
form_dict = self.__dict__ #获取对象的所有字段
#{host:"","ip":""}
for key, regular in form_dict.items():
post_value = request.get_argument(key) #获取用户传过来的参数
# 让提交的数据 和 定义的正则表达式进行匹配
ret = re.match(regular, post_value)
print key,ret,post_value
if not ret:
return False
return True class MainHandler(tornado.web.RequestHandler):
def get(self):
self.render('index.html',name='Chales')
def post(self, *args, **kwargs): #获取用户form表中的数据,然后验证
obj = MainForm()
#验证通过
result = obj.check_valid(self)
print result
self.write('ok') settings = {
'template_path': 'template',
'static_path': 'static',
'static_url_prefix': '/static/',
} application = tornado.web.Application([
(r"/index", MainHandler),
], **settings) if __name__ == "__main__":
application.listen()
tornado.ioloop.IOLoop.instance().start()
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
{{name}}
<h1>hello</h1>
<form action="/index" method="post"> <p>hostname: <input type="text" name="host" /> </p>
<p>ip: <input type="text" name="ip" /> </p>
<p>port: <input type="text" name="port" /> </p>
<p>phone: <input type="text" name="phone" /> </p>
<input type="submit" value="submit" />
</form>
</body>
</html>

六、如何在自定义的脚本中调用model

#!/usr/bin/env python
# _*_ coding:utf-8 _*_
__author__ = "charles" import os os.environ["DJANGO_SETTINGS_MODULE"]="s12crm.settings"
import django django.setup() from crm.models import UserProfile
entry = UserProfile.objects.last() print entry

  

Django自定义分页、bottle、Flask的更多相关文章

  1. Django自定义分页并保存搜索条件

    Django自定义分页并保存搜索条件 1.自定义分页组件pagination.py import copy class Pagination: def __init__(self, current_p ...

  2. Django 自定义分页类

    分页类代码: class Page(object): ''' 自定义分页类 可以实现Django ORM数据的的分页展示 输出HTML代码: 使用说明: from utils import mypag ...

  3. Django—自定义分页

    分页功能在每个网站都是必要的,对于分页来说,其实就是根据用户的输入计算出应该显示在页面上的数据在数据库表中的起始位置. 确定分页需求: 1. 每页显示的数据条数 2. 每页显示页号链接数 3. 上一页 ...

  4. Django - 自定义分页、FBV和CBV

    一.自定义分页(优势在于能够保存搜索条件) """ 分页组件使用示例: 1) 先取出所有数据USER_LIST 2) 实例化: obj = Pagination(requ ...

  5. Django——自定义分页(可调用)

    1.view from django.shortcuts import render,HttpResponse # Create your views here. from app01.models ...

  6. django 自定义分页,网址存储缓存,CBV

    1. 通过切片控制分页 自定义分页: from django.shortcuts import render # Create your views here. from app01.models i ...

  7. Django自定义分页

    分页 自定义分页 稳扎稳打版 def book(request): # 从URL取参数(访问的页码) page_num = request.GET.get("page") try: ...

  8. django自定义分页控件

    1.准备数据 在models创建测试表 from django.db import models class Host(models.Model): hostname = models.CharFie ...

  9. Django 自定义分页

    1.路由 urls.py url(r'^index2.html/', views.index2), 2.views.py def index2(request): # 数据总条数 当前页 每页显示条数 ...

随机推荐

  1. 【转】15个无比华丽的HTML5/CSS3动画应用

    原文转自:http://www.html5cn.org/article-7089-1.html 前几天,HTML5标准已经尘埃落定,未来的Web将会是由HTML5主导,当然作为开发者对这一喜讯更为动心 ...

  2. Android 学习第2课,下载 eclipse 工具

    可以到http://www.ddooo.com/softdown/61745.htm 下载下来是32位与64位都有的 而且是汉化的,经测试成功,还可以,不错!

  3. 《JavaScript模式》第5章 对象创建模式

    @by Ruth92(转载请注明出处) 第5章:对象创建模式 JavaScript 是一种简洁明了的语言,并没有其他语言中经常使用的一些特殊语法特征,如 命名空间.模块.包.私有属性 以及 静态成员 ...

  4. 开启software protection报错

    错误:             我把激活Win8的拿去激活7了 ,开了oem/efi后就ID不可用.开启software protection开不了,错误2.找不到指定文件.用其他软件重新激活则是弹出 ...

  5. C++ Primer 第5版

    说起Lippman的C++ Primer,我总是有种特殊感情.这本书既是我进入C++领域的敲门砖,也是我第一次在网络上发表技术文章的对象.当年读书笔记中的青涩迷惘和年少轻狂都还历历在目,转眼已经从第三 ...

  6. HTML、html

    1.HTTPS(超文本传输协议,HyperText Transfer Protocol)        超文本传输协议HTTP协议被用于在Web浏览器和网站服务器之间传递信息.HTTP协议以明文方式发 ...

  7. MindProject R6025解决

    -- 来之百度贴吧,收藏在此. 不知道吧里有没有人用mindmanager2012,如果用的话会发现保存.mmap文件后,移动到其他地方,再打开,就会出错,软件关闭.网上很多人说是模版里tips的原因 ...

  8. nodejs项目在webstorm里进行debug的设定

    菜单 > Run > Edit Configurations... 菜单 > Run > Debug... 菜单 > Run > Edit Configuratio ...

  9. php分10个不同等级压缩优化图片

    今天找到一个php写的压缩图片程序,可以分10个等级(0-9)来压缩,0等级时压缩比率不是很大,图片不会失真:随着压缩等级不断增大,图片会变得越来越不清晰,通常压缩后图片大小可以减少到原来的50%,压 ...

  10. SPRING + THYMELEAF 配置

    1.使用的是Spring EL而不是Ognl.2.访问上下文的Bean用${@myBean.doSomething()}3.th:field,th:errors,th:errorclass用于form ...