Django创建一个后台的基本步骤记录

作者:七月__ 时间:2021-03-19 02:13:38 

1.首先分析要做的项目的结构,整理出关系图

2.运行 python manage.py startapp XXX 创建一个app

3.根据关系图设计models层,理清关系,设计好数据结构

4.在settings的位置配置app所在的位置

5.运行python manage.py makemigrations

6.运行 python manage.py migrate

7配置后台 建议运用装饰器如下:


@admin.register(模块类名)
class 模块类名Admin(admin.ModelAdmin):
配置的代码,比如显示什么 等等

8.运行python manage.py createsuperuser 然后根据提示输入用户名和邮箱等个人信息,其中邮箱可为空,密码在输入的时候不显示在控制台.

10.在定义models字段时经常需要遇到根据请求来源改变用户名的时候,可将方法重写如下:


def save_model(self, request, obj, form, change):
 obj.owner = request.user
 return super(模块类名Admin, self).save_model(request,obj,form,change)

此时的list_display列表 owner 字段 就会根据请求的不同来源自动赋值

11.在定义模块时没有定义的字段如登陆用户可以在后台进行修改如下:


def 字段名称(self, obj):
 return obj.xxx()

字段名称.short_description = '文本描述'

此时可以在list_display列表里添加 字段名称 这个字段如下:


list_display = [
'name','sex','age','字段名称'
]

12.在每个models的类都添加__str__方法非常重要如下:


def __str__(self):
return self.字段名称

13.如果过滤器()不符合自己的需求那么可以自己定制过滤器,基本思想是找到queryset,然后进行一个过滤,主要是继承了admin.SimpleListFilter类,然后对两个属性和两个方法进行重写,如下:


class 类名Filter(admin.SimpleListFilter):
"""自定义过滤器 """
title = '分类过滤器'
parameter_name = 'owner_category'

def lookups(self, request, model_admin):
 return Category.objects.filter(筛选条件).values_list('参数1,必须是主键', '参数2,显示在界面上的内容')

def queryset(self, request, queryset):
 category_id = self.value()
 if category_id:
  return queryset.filter(category__id=category_id)
 return queryset

@admin.register(类名)
class 类名Admin(admin.ModelAdmin):

list_filter = [类名Filter]

14.若显示界面的内容也就是 list_display的内容不符合预期,我们也可以进行定制.主要原理还是找到queryset在哪里生成也就是数据源的位置进行过滤即可,一般都是get_queryset方法是最后生成queryset的位置.如下:


def get_queryset(self, request):
 qs = super(PostAdmin, self).get_queryset(request)
 return qs.filter(筛选条件)

介于本人学习的进度,编辑页面的配置日后补齐

来源:https://blog.csdn.net/qq_15506981/article/details/108886181

标签:django,创建,后台
0
投稿

猜你喜欢

  • Python中itertools模块用法详解

    2023-05-28 05:00:27
  • 用pip给python安装matplotlib库的详细教程

    2021-02-02 00:02:45
  • Python将多个excel表格合并为一个表格

    2021-10-18 22:50:22
  • 详解Vuex管理登录状态

    2024-04-26 17:38:02
  • SqlServer数据库备份与还原的实现步骤

    2024-01-28 13:08:40
  • 详解MySQL 慢查询

    2024-01-26 19:00:58
  • Python Opencv实战之文字检测OCR

    2023-03-18 14:05:41
  • PYQT5开启多个线程和窗口,多线程与多窗口的交互实例

    2023-07-19 04:21:21
  • 用FSO操作 xml

    2008-09-03 12:26:00
  • 解决SpringBoot启动过后不能访问jsp页面的问题(超详细)

    2023-06-13 19:43:31
  • python经典趣味24点游戏程序设计

    2022-05-14 12:13:20
  • SQL Server存储过程中编写事务处理的方法小结

    2024-01-15 15:24:24
  • Python实现遗传算法(虚拟机中运行)

    2022-07-10 18:48:07
  • 详解Python中的测试工具

    2022-07-02 09:10:13
  • [翻译]标记语言和样式手册 Chapter 14 图片替换

    2008-02-18 12:56:00
  • php错误级别的设置方法

    2023-11-24 10:30:35
  • python使用dlib进行人脸检测和关键点的示例

    2021-12-14 20:56:04
  • vue实现input输入模糊查询的三种方式

    2024-05-08 10:42:12
  • 使用 Python 清理收藏夹里已失效的网站

    2023-01-11 01:26:00
  • python 按照固定长度分割字符串的方法小结

    2021-05-28 06:05:05
  • asp之家 网络编程 m.aspxhome.com