Django1.8教程——从零开始搭建一个完整django博客(二)
在上一节中,我们已经创建了一个Django模型Post,并使Post模型与数据库同步。这一节中,我们将介绍Django管理站点,通过Django管理站点来管理我们创建的Post模型实例。
为你的模型创建一个控制管理站点
好了,我们已经定义了一个post模型,现在,我们将要创建一个简单的管理站点,来管理post实例。Django自带的管理界面是一个十分强大的内容编辑器。Django管理站点按照你模型的元数据动态建立,并且提供一个方便编辑内容的接口。同样,你也可以在管理站点内自定义如何展现你的模块。
需要记住的一点是django.contrib.admin已经包含在INSTALLED_APPS设置中,这就是为什么我们不需要再手动添加它的原因。
创建管理员权限用户
首先,我们需要创建一个管理员权限用户来登录管理站点,运行下面命令:
python manage.py createsuperuser
你会看到以下内容,并提示你输入用户名、e-mail,密码:
Username (leave blank to use 'admin'): admin
Email address: admin@admin.com
Password: ********
Password (again): ******** Superuser created successfully.
Django管理站点
现在,运行开发服务器(python manage.py runserver),在浏览器打开http://127.0.0.1:8000/admin/,你就可以看见管理站点登录界面。

输入你刚刚建立的管理员用户名和密码,登录管理站点,你会看见管理站点的首页。

现在你所看见的User和Group模块是Django的认证框架,这是在INSTALLED_APPS中的django.contrib.auth设置的。如果你打开Users,你会看见刚刚创建的管理员。blog应用中的Post模型和User模型之间有关联关系。这段关联被定义在Post模型中的author属性。
将你的模型添加到管理站点
现在将我们创建的blog应用中的Post模型添加至管理站点。编辑blog应用中的admin.py文件:
from django.contrib import admin
from .models import Post
admin.site.register(Post)
现在,重新加载管理站点,你就可以看见你的Post模型已经添加至管理站点。

这很容易,对吗?当你在Django管理站点登记一个模型,就会得到一个友好的用户界面:允许你生成对象列表;以及非常容易的编辑、创建、删除对象。

Django针对不同的字段使用不同的表格插件,像DateTimeField,在管理站点中展示一个类似JavaScript日历插件的界面。将所有内容添加完毕之后,点击保存按钮。站点就会跳转到post列表页,并且给出一个”你已成功添加post“的提示。

自定义管理站点中的模块显示
现在我们将看到如何自定义管理站点。编辑你的blog应用中的admin.py文件:
from django.contrib import admin
from .models import Post
class PostAdmin(admin.ModelAdmin):
list_display = ('title', 'slug', 'author', 'publish', 'status')
admin.site.register(Post, PostAdmin)
我们告诉Django管理站点,我们使用继承自ModelAdmin的自定义类,来将我们的Post模型注册到管理站点。在这个自定义类中,我们定义了如何展示Post模型。list_display属性允许你设置你想要在管理对象列表页面显示的模型字段。
现在我们为管理站点添加其他选项:
class PostAdmin(admin.ModelAdmin):
list_display = ('title', 'slug', 'author', 'publish', 'status')
list_filter = ('status', 'created', 'publish', 'author') search_fields = ('title', 'body')
prepopulated_fields = {'slug': ('title',)}
raw_id_fields = ('author',)
date_hierarchy = 'publish'
ordering = ['status', 'publish']
重新加载管理站点,可以看到:

你可以看到post对象列表页面中显示出你在list_display中定义展示的字段。
列表页包括一个右边栏,允许你通过在list_fliter定义的过滤器字段来筛选文章。
在页面上出现了一个搜索栏。这是因为我们已经使用search_fields属性定义了可搜索字段。
搜索栏下面一栏,由date_hierarchy属性定义,提供一个基于日期层次的快速指向。
您还可以看到,post对象按照Status和Publish排序,你还可以使用ordering属性定义默认的排序方式。
现在点击Add post链接,进入post对象编辑界面。当你把新创建的post对象的标题输入title字段的时候,你会发现,slug字段自动填充了相应的内容。这是因为我们用prepopulated_fields属性告诉Django,slug是title的关联字段。另外,现在作者字段将显示一个查找控件,因为当你的注册用户成百上千的时候,从下拉列表选择十分的不方便。

看看,我们只用了短短几行代码,就在管理站点中定义了模型的管理方式。定制和扩展Django管理站点的方法还有很多,在后面的章节,我们将进一步为你揭晓。
原文链接:http://www.landsblog.com/blog/content/djangoexamplemanage
更多教程:http://www.landsblog.com/blog/tag/django
Django1.8教程——从零开始搭建一个完整django博客(二)的更多相关文章
- Django1.8教程——从零开始搭建一个完整django博客(一)
第一个Django项目将是一个完整的博客网站.它和我们博客园使用的博客别无二致,一样有分类.标签.归档.查询等功能.如果你对Django感兴趣的话,这是一个绝好的机会.该教程将和你一起,从零开始,搭建 ...
- Django1.8教程——从零开始搭建一个完整django博客(三)
这一节主要介绍对数据库的访问操作:通过管理器(manage),对对象进行检索.修改.删除等操作,详细介绍了如何针对不同的模型自定义管理器. 查询和管理工作 现在,我们已经有了一个功能完善的Django ...
- 用express搭建一个简单的博客系统
转自:https://blog.csdn.net/qq_29721837/article/details/62055603 Express 简介 Express 是一个简洁而灵活的 node.js W ...
- 使用Hexo搭建一个简单的博客(二)
昨天想着用Hexo和github搭一个自己简单的博客,记录一下自己踩过的坑,具体的流程就不重复了,主要参考了一下几篇文章 GitHub+Hexo 搭建个人网站详细教程 使用Hexo+Github一步步 ...
- 使用Hexo搭建一个简单的博客(一)
搭建好简洁的博客框架后,回看时发现,简洁之中透露着一丝丝简陋,好的,网上关于丰富hexo的文章也很多 记录一下自己的一些瞎操作. 在你的hexo目录下,你可以看到themes文件夹里有个默认的land ...
- 使用Hugo,只需5分钟,轻松搭建一个自己的博客
前面跟大家介绍过hexo这款静态博客系统,功能强大,基本能满足博客的各种需求.今天,我再跟大家介绍一款优秀的静态博客系统,那就是Hugo. Hugo是由Go语言实现的静态网站生成器.简单.易用.高效. ...
- Express入门教程:一个简单的博客
来自: http://ourjs.com/detail/56b2a6f088feaf2d031d2468 Express 简介 Express 是一个简洁而灵活的 node.js Web应用框架, ...
- 从零开始搭建一个react项目
Nav logo 120 发现 关注 消息 4 搜索 从零开始搭建一个react项目 96 瘦人假噜噜 2017.04.23 23:29* 字数 6330 阅读 32892评论 31喜欢 36 项目地 ...
- react全家桶从0搭建一个完整的react项目(react-router4、redux、redux-saga)
react全家桶从0到1(最新) 本文从零开始,逐步讲解如何用react全家桶搭建一个完整的react项目.文中针对react.webpack.babel.react-route.redux.redu ...
随机推荐
- C/S架构程序多种类服务器之间实现单点登录(转)
(一) 在项目开发的过程中,经常会出现这样的情况:我们的产品包括很多,以QQ举例,如登陆.好友下载.群下载.网络硬盘.QQ游戏.QQ音乐等,总不能要求用户每次输入用户名.密码吧,为解决这个问题,高手提 ...
- statement和preparedstatement用法区别
1. PreparedStatement接口继承Statement, PreparedStatement 实例包含已编译的 SQL 语句,所以其执行速度要快于 Statement 对象. 2.作为 ...
- Sping mvc 环境下使用kaptcha 生成验证码
一.kaptcha 的简介 kaptcha 是一个非常实用的验证码生成工具.有了它,你可以生成各种样式的验证码,因为它是可配置的.kaptcha工作的原理是调用 com.google.code.kap ...
- ASP.NET5 MVC6入门教学之一(自己动手)
等待微软开源大动作已经好几年了,终于ASP.NET 5发布了.今天给新手们写一个简单地教程,教你认识一下ASP.NET5 MVC6 1.安装kvm 首先,你需要以管理员权限打开cmd,执行如下的脚本: ...
- Post-office 树状数组
Post office 题目描述 There are N(N<=1000) villages along a straight road, numbered from 1 to N for si ...
- hdu 1398 Square Coins(简单dp)
Square Coins Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Pro ...
- [转]Ionic + AngularJS angular-translate 国际化本地化解决方案
本文转自:http://www.cnblogs.com/maoyazhi/p/4332362.html 欢迎访问我们的网站,网站上有更多关于技术性的交流:http://www.ncloud.hk/技术 ...
- 关于TouchEvent里面的touches,targetTouches,changedTouches的解释
touches:手指触摸到屏幕上引起的当前所有触摸点的集合; targetTouches:手指触摸到绑定事件的节点上的触摸点的集合; changedTouches:触摸事件时改变触摸点的集合; 以下 ...
- RabbitMQ 一二事 - 简单队列使用
消息队列目前流行的有三种 1. RabbitMQ 2. ActiveMQ 3. Kafka 这三种都非常强大,RabbitMQ目前用的比较多,也比较流行,阿里也在用 ActiveMQ是阿帕奇出品,但是 ...
- ehcache 一二事 - ssm 中ehcashe的简单配置应用
Ehcache是一个开源Java分布式缓存.可以配合mybatis来使用 首先,在资源文件夹中新建ehcache.xml 内容如下: <?xml version="1.0&qu ...