1、将添加blog的后台基本操作
在blog文件夹下新建一个admin.py文件加入一下代码:
-
from django.contrib import admin
-
from djcms.apps.blog.models import Post, Category, Tag
-
-
admin.site.register(Post)
-
admin.site.register(Category)
-
admin.site.register(Tag)
重启服务,再到浏览器上登录到后台,是不是增加了对blog的基本操作,不仅比较完善、界面整洁优雅,而且很多都可以自定义,是不是很酷!后续再慢慢研究。
2、汉化表单、完善表单
目前位置,后台的表单前面的标签label基本上都是默认的字段名字,各种表单也是初始的状态,下面我们简单做些修改。修改后的模型代码如下:
- # coding:utf8
-
from django.db import models
-
-
class Category(models.Model):
-
"""
- 文章分类
-
"""
-
title = models.CharField('名称', max_length=100) # 分类名称
-
alias = models.CharField('别名', max_length=100) # 分类别名(用于 url 优化)
-
sort = models.SmallIntegerField('排序') # 排序
-
-
class Meta:
-
verbose_name = '分类'
-
verbose_name_plural = '分类'
-
ordering = ['sort']
-
-
def __unicode__(self):
-
return self.title
-
-
class Tag(models.Model):
-
"""
- 文章标签
-
"""
-
tagname = models.CharField('标签名', max_length=60) # 标签名
-
post_ids = models.TextField(editable=False) # 对应的文章 id 集合的序列
-
-
class Meta:
-
verbose_name = '标签'
-
verbose_name_plural = '标签'
-
-
def __unicode__(self):
-
return self.tagname
-
-
class Post(models.Model):
-
"""
- 博客文章
-
"""
-
# 文章发布状态
-
CONTENT_STATUS_PUBLISHED = 1
-
# 文章草稿箱状态
-
CONTENT_STATUS_DRAFT = 2
-
# 文章状态选项
-
CONTENT_STATUS_CHOICES = (
-
(CONTENT_STATUS_PUBLISHED, '发布'),
-
(CONTENT_STATUS_DRAFT, '草稿箱'),
-
)
-
-
title = models.CharField('标题', max_length=100) # 标题
-
content = models.TextField('文章内容') # 内容
-
excerpt = models.TextField('摘要') # 摘要
-
publish_date = models.DateTimeField('发表时间') # 发表时间
-
status = models.IntegerField('状态',
-
choices=CONTENT_STATUS_CHOICES,
-
default=CONTENT_STATUS_PUBLISHED) # 状态:1为正式发布,2为草稿箱
-
comments_count = models.IntegerField(default=0, editable=False) # 评论总数
-
view_count = models.IntegerField(default=0, editable=False) # 浏览总数
-
-
alias = models.CharField('别名', max_length=100, blank=True) # 别名(用于 url 优化)
-
keywords = models.CharField('关键字', max_length=500, blank=True) # 关键字
-
description = models.TextField('描述', blank=True) # 描述
-
-
user = models.ForeignKey("auth.User",
-
verbose_name = '作者',
-
related_name="%(class)ss") # 作者
-
categories = models.ManyToManyField(Category, blank=True,
-
verbose_name = '分类',
-
related_name="posts") # 分类
-
-
class Meta:
-
verbose_name = '文章'
-
verbose_name_plural = '文章'
-
ordering = ['publish_date']
-
-
def __unicode__(self):
-
return self.title
其中将文章状态选项CONTENT_STATUS_CHOICES 写在Post类中更加合理,而Meta中的verbose_name表示单数形式的显示,verbose_name_plural表示复数形式的显示,因为中文的单数和复数一般不作区别,如果是英文一般默认会的复数是加上了s
进一步完善文章的列表显示和表单,在blog下面的admin.py文件中加入PostAdmin类:
-
class PostAdmin(admin.ModelAdmin):
-
list_display = ('title', 'publish_date', 'user', 'status') # 列表显示的字段
-
search_fields = ('title',) # 列表包含根据指定字段搜索
-
list_filter = ('publish_date',) # 右侧过滤选项
-
-
# 分组表单
-
fieldsets = (
-
('基本信息', {'fields': ('title', 'content', 'excerpt', 'publish_date','status', 'user', 'categories')}),
-
('Meta Data', {'fields': ('alias', 'keywords', 'description')}),
-
)
代码的作用都有注释,就不详述了,更改后的文章列表页为下面效果:
添加和编辑文章的表单是不是也变得和你想要的比较接近了!在此就不截图了!
注意,有3种类型的域不能按如上方式添加自定义名称:ManyToManyField,OneToOneField,ForeignKey。而应该显示指定:
class Film(models.Model):
title = models.CharField('片名', max_length=100)
actors = models.ManyToManyField(Actor,verbose_name='演员')
pub_date = models.DateField('发行日期')
publisher = models.ForeignKey(Publisher,verbose_name='发行商')
如果想修改通过admin自动生成的后台管理标题 请用国际化处理, 如果改变布局可以重写admin的页面
转自 http://www.yakecan.com/archives/998
分享到:
相关推荐
本文将介绍如何在Django admin界面中将英文的字段显示和文字信息汉化为中文。 首先,在Django项目中,模型(model)是数据的基本单元,一个模型相当于数据库中的一张表。模型的元数据定义在内部类Meta中,其中verbose...
"Python-djangoadmin美化采用layui作为基本框架改写大部分页面"这个项目旨在提升Django内置的admin界面的用户体验,通过引入layui这一现代前端框架,对默认的admin模板进行了全面的改造。 layui是一款优秀的前端UI...
Django是Python语言编写的一个开源的web框架,它采用MTV的框架模式,即Model(模型)、Template(模板)、View(视图)。Django Admin则是Django框架自带的一个后台管理系统,它提供了一个方便的管理界面给开发者...
【django-admin-bootstrap-master.zip】是一个包含Django管理界面(admin)风格化为Bootstrap主题的项目压缩包。这个项目旨在提供一个美观、响应式且用户体验友好的Django后台管理界面。Bootstrap是一个流行的前端...
django-model-report, Django 报告与highcharts集成 Django 模型报告django-model-report是与highcharts集成的报告的Django 应用程序和库。 现在,由 @jelenak 维护。演示http://django-model-report.hero
本项目是一款基于Django框架和ECharts图表库的Django Admin统计图设计源码。该源码包共包含95个文件,其中包括38个JavaScript文件、18个Python编译文件、18个Python源文件、8个XML文件、3个Git忽略文件、2个Markdown...
"django-admin-env-notice" 应用的核心功能就是在Django Admin的顶部添加一个明显的提示,显示当前环境的信息,如"开发"、"测试"或"生产"。这样,当开发者访问Admin界面时,他们可以立即看到当前是在哪个环境工作,...
**Django Admin Bootstrapped** 是一个专门为Django框架设计的第三方应用,它提供了一个基于Twitter Bootstrap的美化版Django管理界面(admin site)。Bootstrap是一个流行的前端开发框架,用于构建响应式、移动优先...
该项目是一款基于Flask和Layui的DjangoAdmin风格模块化敏捷开发框架设计源码,包含873个文件,涵盖264个JavaScript文件、232个GIF文件、117个PNG文件、92个HTML文件、86个Python文件、48个CSS文件、6个Git忽略文件、...
然而,我们可以通过创建自定义的`AdminModel`类来定制显示和操作。例如,我们可以为`Author`模型创建一个自定义的Admin类: ```python # admin.py class AuthorAdmin(admin.ModelAdmin): list_display = ['name', ...
django-foldable-admin django-foldable-admin允许折叠/扩展应用程序部分。 :skull_and_crossbones: 此项目不再受支持 :skull_and_crossbones: 要求: Django> = 1.8(自Django> = 2起未在新版本上进行测试) ...
2. **自定义显示**:可以通过重写模型的`__str__()`方法来定制模型实例在Admin中的显示方式。 3. **字段选项**:可以设置每个字段的可读性、可编辑性,甚至添加自定义的表单字段。 4. **视图定制**:可以创建...
在Django Admin中,添加自定义控件到详情表单显示是一个常见的需求,尤其是在需要对数据进行更复杂的操作或提供额外交互功能时。本篇主要介绍如何在Django Admin的ModelAdmin详情视图中实现这一功能。 首先,理解...
通过深入学习和理解这个毕设项目,学生不仅可以提升Python和Django的实战技能,还能了解到如何组织和管理Web项目的文件结构,以及如何利用Django的admin后台进行高效的数据管理。这将为未来的职业生涯打下坚实的基础...
本篇文章将详细讲解如何重写Django Model的`save()`方法以及在使用`update()`时可能遇到的问题。 首先,我们来看`save()`方法的重写。`save()`方法是Django Model中用于将对象保存到数据库的内置方法。当你创建一个...
django-admin-dialog 显示一个对话框弹出窗口,其中包含针对您所指定的管理字段的帮助文本。 要求 django-redactoreditor 安装 通过pip安装应用程序: $ pip install django-admin-dialog 将django_admin_dialog...