1.增删改查

  add

    obj = Obj(atr=atr..)

    obj.save()

  update:

    __dict__ 遍历

    

  del:

    根据id列表删除

    

  query:

    首次查询:

      直接跳转至页面,前端页面自动调用ajax异步方法查询

    根据条件查询:

      使用分页类和将参数字典化传入

 

工具:

  将request.POST or request.GET 的 keyValue turn into dictionary, 配合method (**kwargs)

    

  分页工具:

  

		# 分页查询工具类
class Pagination(object):
def __init__(self, totalCount, currentPage, perPageItemNum, maxPageNum):
# 数据总个数
self.total_count = totalCount
# 当前页
try:
v = int(currentPage)
if v <= 0:
v = 1
self.current_page = v
except Exception as e:
self.current_page = 1
# 每页显示的行数
self.per_page_item_num = perPageItemNum
# 最多显示页面
self.max_page_num = maxPageNum def start(self):
return (self.current_page-1) * self.per_page_item_num def end(self):
return self.current_page * self.per_page_item_num @property
def num_pages(self):
"""
总页数
"""
a, b = divmod(self.total_count, self.per_page_item_num)
if b == 0:
return a
return a+1 @property
def pager_num_range(self):
# self.current_page 当前页
# self.per_pager_num 每页显示条数
# self.num_pages 总页数
# self.max_page_num page导航栏总页数
if self.num_pages < self.max_page_num:
return range(1, self.num_pages+1)
# 总页数特别多 5
part = int(self.max_page_num/2)
if self.current_page <= part:
return range(1, self.max_page_num+1)
if (self.current_page + part) > self.num_pages:
return range(self.num_pages-self.max_page_num+1, self.num_pages+1)
return range(self.current_page-part, self.current_page+part+1) def to_dict(self):
return json.loads(json.dumps({'current_page': self.current_page, 'num_pages': self.num_pages,
'max_page_num': self.max_page_num, 'per_pager_num': self.per_page_item_num,
'pager_num_range': self.pager_num_range,})) def page_str(self):
"""
在后台封装前台分页导航栏,适用于单页面参数
前端页面引用方法:
<ul class="pagination pagination-sm" style="margin: 0 0">
{{ page_obj.page_str | safe }}
<ul>
:return: 分页导航栏
"""
page_list = []
first = "<li><a href='?p=1'>首页</a></li>"
page_list.append(first) if self.current_page == 1:
prev = "<li><a href='#'>上一页</a></li>"
else:
prev = "<li><a href='?p=%s'>上一页</a></li>" % (self.current_page-1,)
page_list.append(prev)
for i in self.pager_num_range():
if i == self.current_page:
temp = "<li class='active'><a href='?p=%s'>%s</a></li>" % (i, i)
else:
temp = "<li><a href='?p=%s'>%s</a></li>" % (i, i)
page_list.append(temp) if self.current_page == self.num_pages:
nex = "<li><a href='#'>下一页</a></li>"
else:
nex = "<li><a href='?p=%s'>下一页</a></li>" % (self.current_page + 1,)
page_list.append(nex) last = "<li><a href='?p=%s'>尾页</a></li>" % (self.num_pages,)
page_list.append(last) return ''.join(page_list)

  

最新文章

  1. ObjC宏定义-预编译小功能
  2. python基础知识理解
  3. nyoj739_笨蛋难题四
  4. PowerDesigner更改数据库类型
  5. ReactNative学习-滑动查看图片第三方组件react-native-swiper
  6. 10、JPA_映射双向多对多的关联关系
  7. bzoj1412: [ZJOI2009]狼和羊的故事
  8. oracle数据库获取指定表的列的相关信息
  9. docker基础入门之一
  10. Windows上安装MongoDB步骤
  11. 多重bash登入的history写入问题
  12. CSS深入理解学习笔记之float
  13. Git 上传 GitHub
  14. 别人的Linux私房菜(19)认识与分析日志文件
  15. ceph学习
  16. win10安装pycharm及汉化包
  17. GUID生成函数
  18. C++思考
  19. Artech的MVC4框架学习——第八章View的呈现
  20. Kotlin新语言简介和快速入门知识点

热门文章

  1. Java学习笔记10---访问权限修饰符如何控制成员变量、成员方法及类的访问范围
  2. 浅谈 URI 及其转义
  3. Java学习笔记15(面向对象八:匿名对象、内部类)
  4. 用call和ret实现子程序
  5. (6综合实验)从零开始的嵌入式图像图像处理(PI+QT+OpenCV)实战演练
  6. EF Core 使用编译查询提高性能
  7. 软件安装之-------VM虚拟机安装windows系统
  8. flask-日料网站搭建-数据库操作
  9. oracle练习--@余生请指教多
  10. Activiti 5.22.0 之自由驳回任务实现(亲测)