django自带的序列化组件

本文介绍了Django自带的序列化组件,包括简易和带页码的分页器,以及如何进行优化。同时讲解了Forms组件的作用,如数据校验、标签渲染和信息展示,并探讨了widgets的使用,特别是在错误信息提示和字段类型的配置上。
摘要由CSDN通过智能技术生成

目录

sweetalert前端插件

django自带的序列化组件

简易分页器

带有页码的分页器

优化后的版本

模块代码

后端代码

Forms组件

校验数据

渲染标签

展示信息

 widgets

注意:


sweetalert前端插件

https://github.com/lipis/bootstrap-sweetalert

django自带的序列化组件

以后我们用的序列化组件是DRF

关键模块

from django.core import serializers

作用>>>>把数据序列化成我们需要的格式

使用

	from django.core import serializers
    def data_json(request):
        data = models.Book.objects.all()
        data_json = serializers.serialize('json',data)  #把QuerySet序列化成JSON格式
        return HttpResponse(data_json)


批量数据处理
'''
主要用来优化大批次数据的数据库操作,提高效率
'''
	def data_batch(request):
        # 1.定义空列表
        data_list = []
        # 2.把数据添加到列表中
        for i in range(1,10000):
            # 获取数据对象
            book_obj = models.Book(title=f'第{i}本书',price=100,stock=1000,sales=1000)
            # 数据对象添加到列表
            data_list.append(book_obj)
        # 3.执行批量操作
        models.Book.objects.bulk_create(data_list)
        return HttpResponse('ok')
分页器推导流程
"""
当数据量非常大时,我们一个页面展示不完,所以就创造了分页器
django本身也自带了一个分页器 只是不好用 所以我们自己写!!!
"""

简易分页器

def my_pager(request):
    # 获取页码
    current_page = request.GET.get('page')
    if not request.GET.get('page'):
        current_page = 1
    # 准备数据参数(以每页十条数据为准)
    start_num = (int(current_page)-1)*10
    end_num = start_num+10
    # 获取切片数据
    data_slice = models.Book.objects.all()[start_num:end_num]
    return render(request,'data_list.html',locals())

'''
通过控制url的pege参数就可以实现分页
'''

带有页码的分页器

def page(request):
    # 准备分页数据
    try:
        current_page = int(request.GET.get('page'))
    except Exception:
        current_page = 1
    # 准备数据参数(以每页十条数据为准)
    start_num = (current_page - 1) * 10
    end_num = start_num + 10
    # 获取切片数据
    data_slice = models.Book.objects.all()[start_num:end_num]
    # 获取数据总条数
    data_num = models.Book.objects.all().count()
    # 获取应该要多少页(以十条每页为标准)
    page_num,more = divmod(data_num,10)
    if more:
        page_num+=1  # 如果有余数,就要多来一页
    # 生成标签
    html = ''
    for i in range(1,page_num+1):
        html +='<li><a href="?page=%s">%s</a></li>'%(i,i)
    return render(request,'data_list.html',locals())

优化后的版本

def pager(request):
    # 准备分页数据
    try:
        current_page = int(request.GET.get('page'))
    except Exception:
        current_page = 1
    # 准备数据参数(以每页十条数据为准)
    start_num = (current_page - 1) * 10
    end_num = start_num + 10
    # 获取切片数据
    data_slice = models.Book.objects.all()[start_num:end_num]
    # 获取数据总
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值