开发实践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 //

相关推荐
十叶知秋1 分钟前
【jmeter】jmeter的线程组功能的详细介绍
数据库·jmeter·性能测试
瓜牛_gn2 小时前
mysql特性
数据库·mysql
奶糖趣多多3 小时前
Redis知识点
数据库·redis·缓存
CoderIsArt4 小时前
Redis的三种模式:主从模式,哨兵与集群模式
数据库·redis·缓存
师太,答应老衲吧6 小时前
SQL实战训练之,力扣:2020. 无流量的帐户数(递归)
数据库·sql·leetcode
Channing Lewis7 小时前
salesforce case可以新建一个roll up 字段,统计出这个case下的email数量吗
数据库·salesforce
毕业设计制作和分享8 小时前
ssm《数据库系统原理》课程平台的设计与实现+vue
前端·数据库·vue.js·oracle·mybatis
ketil278 小时前
Redis - String 字符串
数据库·redis·缓存
Hsu_kk9 小时前
MySQL 批量删除海量数据的几种方法
数据库·mysql
编程学无止境9 小时前
第02章 MySQL环境搭建
数据库·mysql