当前位置: 首页 > news >正文

要怎么做网站排名前十的大学

要怎么做网站,排名前十的大学,网站开发管理课程设计说明,怎么用手机建网站文章目录 分页组件pager组件代码 分页组件 应用分页组件,需要以下两个步骤: 视图函数中:(先获取queryset,将request和queryset传入分页组件对象中,得到生成的html标签) def customer_list(requ…

文章目录

  • 分页组件
    • pager组件代码

分页组件

应用分页组件,需要以下两个步骤:

  1. 视图函数中:(先获取queryset,将request和queryset传入分页组件对象中,得到生成的html标签)

    def customer_list(request):# 所有数据queryset = models.Customer.objects.filter(active=1).select_related('level')pager = Pagination(request, queryset)context = {"queryset": queryset[pager.start:pager.end],"pager_string": obj.html()}return render(request, 'customer_list.html', context)
    
  2. 在页面上:(直接引用即可)

    {% for row in queryset %}{{row.id}}
    {% endfor %}<ul class="pagination">{{ pager_string }}
    </ul>
    

pager组件代码

import copy
from django.utils.safestring import mark_safeclass Pagination(object):""" 分页 """def __init__(self, request, query_set, per_page_count=10):""":param request: 需要用request对象中的GET中的数据进行校验和处理:param query_set: 查询数据库得到的查询集:param per_page_count: 每页显示几条数据"""# 防止分页操作对后续的使用request.GET有影响self.query_dict = copy.deepcopy(request.GET)# 将self.query_dict._mutable设置为True:表示query_dict可修改,默认为Falseself.query_dict._mutable = True# 拿到总数据据数self.query_set = query_settotal_count = query_set.count()self.total_count = total_count# 计算出总共有多少页面self.total_page, div = divmod(total_count, per_page_count)if div:self.total_page += 1# 对url中的请求参数进行校验处理,决定显示那一页page = request.GET.get('page')if not page:page = 1else:if not page.isdecimal():page = 1else:page = int(page)if page <= 0:page = 1else:if page > self.total_page:page = self.total_pageself.page = page# 每页数据条数self.per_page_count = per_page_count# 页面第一条数据self.start = (page - 1) * per_page_count# 页面最后一条数据self.end = page * per_page_countdef html(self):""":return: 生成的当前页面的分页栏html"""pager_list = []if not self.total_page:return ""# 求出生成的分页栏html显示的页面范围if self.total_page <= 11:# 总页码小于11start_page = 1end_page = self.total_pageelse:# 总页码比较多# 判断当前页 <=6: 1~11if self.page <= 6:start_page = 1end_page = 11else:if (self.page + 5) > self.total_page:# 显示最后10页start_page = self.total_page - 10end_page = self.total_pageelse:# 显示前后5页start_page = self.page - 5end_page = self.page + 5# 添加url中的参数,而不是替换:?&age=19&name=123&page=1# 首页self.query_dict.setlist('page', [1])pager_list.append('<li><a href="?{}">首页</a></li>'.format(self.query_dict.urlencode()))# 上一页if self.page > 1:self.query_dict.setlist('page', [self.page - 1])pager_list.append('<li><a href="?{}">上一页</a></li>'.format(self.query_dict.urlencode()))# 当前页+前后5页for i in range(start_page, end_page + 1):self.query_dict.setlist('page', [i])if i == self.page:item = '<li class="active"><a href="?{}">{}</a></li>'.format(self.query_dict.urlencode(), i)else:item = '<li><a href="?{}">{}</a></li>'.format(self.query_dict.urlencode(), i)pager_list.append(item)# 下一页if self.page < self.total_page:self.query_dict.setlist('page', [self.page + 1])pager_list.append('<li><a href="?{}">下一页</a></li>'.format(self.query_dict.urlencode()))# 尾页self.query_dict.setlist('page', [self.total_page])pager_list.append('<li><a href="?{}">尾页</a></li>'.format(self.query_dict.urlencode()))pager_list.append('<li class="disabled"><a>数据{}条{}页</a></li>'.format(self.total_count, self.total_page))pager_string = mark_safe("".join(pager_list))return pager_string

可能用到django框架中QueryDict知识点,可以看看Django框架中的:QueryDict(处理url参数)

若有错误与不足请指出,关注DPT一起进步吧!!!

http://www.mmbaike.com/news/88795.html

相关文章:

  • wordpress获取帖子标签辽源seo
  • 淘宝运营跟做网站哪种工资高重庆seo网站推广费用
  • 青岛抖音seo百度seo快速见效方法
  • 广东哪家网站建设后台管理便捷网站出售
  • 做外贸网站赚钱吗搜索大全引擎入口
  • 网站制作工作室24小时接单打开百度搜索引擎
  • 暴雪战网官方网站入口媒体营销平台
  • 哪有免费的网站建设模板百度广告联盟下载
  • 网站数据库有哪些一句话让客户主动找你
  • 网站源码破解版网络营销课程
  • 江西做网站哪家好凡科网
  • 做网站需要相机吗怎么推广网页
  • 武汉建委官网首页上海不限关键词优化
  • 长沙长沙建设网站网站优化推广价格
  • 物流网站给做软件前端seo是什么意思
  • 武汉电商网站开发百度商城官网首页
  • 建设网站需要的工具营销策划推广公司
  • 泰安人才网福州seo优化
  • 网站推广应该注意什么2022年最新十条新闻
  • 用服务器做网站需要购买域名吗口碑营销的模式
  • 广州外贸网站信息sem工作内容
  • 手机网站制作平台有哪些郑州网络推广公司
  • 制作公司网站怎样收费win10优化大师怎么样
  • 网站开发一年费用总计郑州竞价代运营公司
  • 上海公司网站建设企业查询官网入口
  • 猎奇网站模板百度官网认证多少钱一年
  • 360免费建站连接贵阳关键词优化平台
  • 网站建设有增值税发票吗超级外链自动发布工具
  • 什么是平台内部营销站长之家seo综合
  • 菜鸟建站网中国站长之家域名查询