Django Web 开发指南--第二章笔记
快速搭建简单的blog框架
1、环境:
系统 win7 ;
python:3.4
django:1.8
2、创建mysite工程;
打开命令行,转到某个目录,键入命令:
django-admin startproject mysite
3. 创建blog应用;
在命令行中,转到mysite目录下,键入命令:
python manage.py startapp blog
4. 初始化admin后台数据;
在命令行中,转到mysite目录下,键入命令:
python manage.py syncdb
注意:该过程中需要留心用户和密码信息,以后登录后台时需要再次输入该信息
5.设置admin 应用:
admin 是django自带的后台管理系统。添加blog应用,打开mysite/mysite/settings.py 文件:
# Application definition
INSTALLED_APPS = (
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'blog',
)
在我们创建django项目时,admin就已经创建,打开mysite/mysite/urls.py文件:
from django.conf.urls import include,
url
from django.contrib import admin
urlpatterns = [
# Examples:
# url(r'^$', 'mysite.views.home', name='home'),
# url(r'^blog/', include('blog.urls')),
url(r'^admin/', include(admin.site.urls)),
]
6、启动django 容器
在命令行中,转到mysite目录下,键入命令:
python manage.py runserver
7、访问后台应用
在浏览器中输入 http://127.0.0.1:8000/admin/
弹出窗口中,输入第四步中用户名和密码,即可登录
8. 设计model ,即设计数据库中的表
打开mysite/blog/models.py 文件进行修改:
from django.db import models
from django.contrib import admin
# Create your models here.
class BlogsPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField()
admin.site.register(BlogsPost)
9. 再次初始化数据库
在命令行中,转到mysite目录下,键入命令:
python manage.py makemigrations blog
之后在键入命令:
python manage.py syncdb
10.重启runserver,登录后台,创建文章
输入博客标题,正文、日期时间、点击save 创建博客:
11.设置admin中BlogsPost页面
打开mysite/blog/models.py 文件,做如下修改:
from django.db import models
from django.contrib import admin
# Create your models here.
class BlogsPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField()
class BlogPostAdmin(admin.ModelAdmin):
list_display = ('title','timestamp')
admin.site.register(BlogsPost,BlogPostAdmin)
刷新浏览器
创建BlogPostAdmin类,继承admin.ModelAdmin父类,以列表的形式显示BlogPost的标题和时间。
12.创建模板
在blog项目下创建templates目录(mysite/blog/templates/),在目录下创建模板文件base.html,内容如下:
<html>
<style type="text/css">
body
{
color:#efd;
background:#453;
padding:0 5em;
margin:0
}
h1
{
padding:2em 1em;
background:#675;
}
h2
{
color:#bf8;
border-top:1px dotted #fff;
margin-top:2em;
}
</style>
<body>
<h1>my first the django blog </h1>
<H3>walk beside you <h3>
{% block content %}
{% endblock %}
</body>
</html>
在blog项目下创建templates目录(mysite/blog/templates/),在目录下创建模板文件index.html,内容如下:
{% extends "base.html" %}
{% block content %}
{% for post in blog_list %}
<h2>{{ post.title }}</h2>
<p>{{ post.timestamp }}</p>
<p>{{ post.body }}</p>
{% endfor %}
{% endblock %}
13 . 创建视图
打开mysite/blog/views.py文件:
from django.shortcuts import
render
from blog.models import BlogsPost
from django.shortcuts import render_to_response
# Create your views here.
def index(request):
blog_list = BlogsPost.objects.all()
return render_to_response('index.html',{'blog_list':blog_list})
14 .创建blog的url模式
在mysite/urls.py文件里添加blog的url:
from django.conf.urls import include, url
from django.contrib import admin
urlpatterns = [
# Examples:
# url(r'^$', 'mysite.views.home', name='home'),
# url(r'^blog/', include('blog.urls')),
url(r'^admin/', include(admin.site.urls)),
url(r'^index/$', 'blog.views.index'),
]
15.再次启动服务,访问blog应用
16.总结
页面具有三个典型的组件:
模板(template):负责把传递进来的信息显示出来。
视图(view):负责从数据库获取需要显示的信息。
URL模式:负责把收到的请求和你的试图函数匹配,有时候也会向视图传递一些参数。