开发实践5_project

要求:

(对作业要求的"Student"稍作了变换,表单名称为"Index"。)获得后台 Index 数据,作展示,要求使用分页器,包含上一页、下一页、当前页/总页。

结果:

① preparation (创建用户、app、注册、链接总路由等)

// 创建超级用户 terminal

python manage.py createsuperuser

// 8000端口admin

superuser login

( Create new app, install: )

terminal //

python manage.py startapp page_app

setting //

install

total url //

path('page/', include('page_app.urls', namespace="page")),

② 编写Index table,编写用于展示的views、sub-urls等

models //

python 复制代码
from django.db import models

class Index(models.Model):
    name = models.CharField(max_length=32, verbose_name="statistical index")
    category = models.CharField(max_length=32, verbose_name="application field")
    preference = models.FloatField(verbose_name="subjective recommendation degree")
    description = models.CharField(max_length=128, verbose_name="brief documentation", null=True)

    def __str__(self):
        return f"{self.name}_{self.category}"

    class Meta:
        verbose_name = "Index"
        verbose_name_plural = verbose_name + 'es'

    @classmethod
    def get_list(cls, **kwargs):
        filters = {}
        return cls.objects.filter(**filters)  # objects.all()

app admin 注册表单到admin主页,添加测试数据// //

python 复制代码
from django.contrib import admin

from page_app.models import Index

models = [
    Index,
]

admin.site.register(models)

views //

python 复制代码
from django.shortcuts import render
from django.core.paginator import Paginator, InvalidPage

from djangoProject.settings import PAGE_SIZE
from page_app.models import Index


def list_index(request):
    page_num = request.GET.get("page_num", default=1)  # 页码 可以通过/?page=k传参,路由与视图函数不必维护param
    indexes = Index.get_list()  # <queryset>
    paginator = Paginator(indexes, PAGE_SIZE)
    try:
        data = paginator.page(page_num)
    except InvalidPage:
        data = paginator.page(1)
    return render(request, "staticindex.html", {"data": data, "paginator": paginator})
    # 记得不要locals().减少缓存中的数据量。

setting //

设置分页大小

PAGE_SIZE = 3

templates //

相关推荐
a587691 小时前
Oracle数据库体系结构深度解析:从内核到应用的理论全景
数据库·oracle
高溪流1 小时前
1.MySql概念讲解 及 MySql安装教程
数据库·mysql
语落心生1 小时前
深入doris查询计划以及io调度(四)存储引擎架构
数据库
蓝银草同学1 小时前
MySQL SQL语法详解:带注释的实用示例
前端·数据库
语落心生2 小时前
深入doris查询计划以及io调度(三)查询执行协调器QE
数据库
Hui Baby2 小时前
saga json文件阅读
java·前端·数据库
此生只爱蛋2 小时前
【Redis】RESP协议和库的安装
数据库·redis·缓存
数据库知识分享者小北2 小时前
免费体验《自建 MySQL 迁移至 PolarDB 分布式 V2.0》
数据库·分布式·mysql·阿里云·云原生·polardb
电商API_180079052473 小时前
淘宝商品评论数据抓取指南|API调用演示
大数据·数据库·人工智能·数据分析·网络爬虫
睿思达DBA_WGX4 小时前
Python 程序设计讲义(69):面向对象程序设计——类的定义与使用
数据库·python