在使用Django自带的admin后台的时候,他提供了一些默认的指令可以对数据进行操作,比如批
在使用Django自带的admin后台的时候,他提供了一些默认的指令可以对数据进行操作, 比如批量删除,修改等
同样的我们也可以添加自己的指令。
创建一个Django项目
$ django-admin startproject DjangoActions
$ cd DjangoActions
$ python3 manage.py startapp mysite添加model
打开mysite下的models.py
from django.db import models
class Article(models.Model):
# 文章状态,类似枚举
STATUS_CHOICES = (
('d', '草稿'),
('p', '发布'),
)
# 标题
title = models.CharField(max_length=30)
# 内容
body = models.TextField()
# 状态
status = models.CharField(max_length=1, choices=STATUS_CHOICES, default='d')
def __str__(self):
return self.title将Article注册到admin
打开mysite下的admin.py
from django.contrib import admin
from .models import Article
# 指令处理函数,参数固定写法
def make_article_published(modeladmin, request, queryset):
# queryset 是从数据库查询到的model set
# 更新status状态为p,在此处就是Article
queryset.update(status='p')
# 此指令的名称
make_article_published.short_description = '更改状态为发布'
#将Article注册到后台
@admin.register(Article)
class ArticleAdmin(admin.ModelAdmin):
# 后台列表展示的字段
list_display = ('title', 'status')
# 动作集合
actions = [make_article_published]启动服务
1.首先同步数据库
$ python3 manage.py makemigrations
$ python3 manage.py migrate
2.创建超级用户
$ python3 manage.py createsuperuser按照提示操作即可
3.启动服务
$ python3 manage.py runserver
效果
1.点击MYSITE下面Articles右边的add,添加一个文章。保存文章后会自动跳到文章列表。
2.点击Action右边的option。
我们自己的action已经添加进来了。
可以尝试选择文章前面的checkbox然后将其标记为发布。
将action定义到ModelAdmin内部
上面已经添加好了,一个自定义action但是看起有点不是很直观,不符合封装原理。 我们稍作修改。
from django.contrib import admin
from .models import Article
#将Article注册到后台
@admin.register(Article)
class ArticleAdmin(admin.ModelAdmin):
# 后台列表展示的字段
list_display = ('title', 'status')
# 动作集合 修改为字符串
actions = ['make_article_published']
# 指令处理函数,参数固定写法
def make_article_published(self, request, queryset):
# queryset 是从数据库查询到的model set
# 更新status状态为p,在此处就是Article
queryset.update(status='p')
# 操作完成后的提示信息
self.message_user(request, '修改成功')
# 此指令的名称
make_article_published.short_description = '更改状态为发布'
重起服务器,再次修改状态,依旧执行成功,而且还有提示信息
跳转到中间页面
Django默认执行完动作后会返回到当前页面并刷新,同样我们也可以自定义跳转到其他页面。 只需在动作函数上返回一个HttpResponse即可。
views.py
from django.shortcuts import render
def success(request):
return render(request, 'success.html')
DjangoActions/urls.py
from mysite.views import success
urlpatterns = [
path('admin/', admin.site.urls),
path('success/', success, name='success'),
]
templates/success.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
success
</body>
</html>
mysite/admin.py
from django.contrib import admin
from .models import Article
from django.shortcuts import redirect
#将Article注册到后台
@admin.register(Article)
class ArticleAdmin(admin.ModelAdmin):
# 后台列表展示的字段
list_display = ('title', 'status')
# 动作集合 修改为字符串
actions = ['make_article_published']
# 指令处理函数,参数固定写法
def make_article_published(self, request, queryset):
# queryset 是从数据库查询到的model set
# 更新status状态为p,在此处就是Article
queryset.update(status='p')
# 此处使用的转发,一可以直接使用HttpResponse
return redirect('success')
# 此指令的名称
make_article_published.short_description = '更改状态为发布'
再次尝试修改,成功后会跳转到
整个站点的action
有时候为了方便,可能这个站点都有一个相同的动作,那么每一个modelAdmin都写一遍似乎有点傻,我们 可以配置整个站点的action解决问题。
使用方式:
from django.contrib import admin
admin.site.add_action(make_article_published)
禁用action
禁用全站级别的acitons:
# 禁用默认的删除
admin.site.disable_action('delete_selected')
全站禁用,个别可用 启用了全站禁用,某个又想使用怎么办,只需单独添加到actions里面就可以了
# 禁用默认的删除
admin.site.disable_action('delete_selected')
@admin.register(Article)
class ArticleAdmin(admin.ModelAdmin):
# 后台列表展示的字段
list_display = ('title', 'status')
# 动作集合
actions = ['delete_selected']
在指定模型中禁用所有actions 如果将模型中的actions=None
那么所有的action都不可用,包括系统默认的
@admin.register(Article)
class ArticleAdmin(admin.ModelAdmin):
# 后台列表展示的字段
list_display = ('title', 'status')
# 动作集合
actions = None
根据条件自动启用或禁用
#将Article注册到后台
@admin.register(Article)
class ArticleAdmin(admin.ModelAdmin):
# 后台列表展示的字段
list_display = ('title', 'status')
# 动作集合 修改为字符串
actions = ['make_article_published']
# 指令处理函数,参数固定写法
def make_article_published(self, request, queryset):
# queryset 是从数据库查询到的model set
# 更新status状态为p,在此处就是Article
queryset.update(status='p')
# 此处使用的转发,一可以直接使用HttpResponse
return redirect('success')
# 重写此方法,做出判断即可
def get_actions(self, request):
actions = super(ArticleAdmin, self).get_actions(request)
if request.user.username[0].upper() != 'SuperUser':
if 'delete_selected' in actions:
del actions['delete_selected']
return actions
# 此指令的名称
make_article_published.short_description = '更改状态为发布'
总结
以上所述是小编给大家介绍的Django给admin添加Action的方法实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
django admin django action