首页 > 其他 > 详细

blog (后续更新)

时间:2016-09-10 14:39:38      阅读:186      评论:0      收藏:0      [点我收藏+]

 

 

设计Model(设计数据库)

from django.db import models

# Create your models here.

class BlogsPost(models.Model):
    title =models.CharField(max_length=150)  #标题
    body =models.TextField()   ##内容
    timestamp = models.DateTimeField() ##时间

初始化数同步据库

python manage.py makemigrations
python manage.py migrate

  

创建blog的公共部分

从Django的角度看,一个页面具有三个典型的组件:

一个模板(template):模板负责把传递进来的信息显示出来。

一个视图(view):视图负责从数据库获取需要显示的信息。

一个URL模式:它负责把收到的请求和你的试图函数匹配,有时候也会向视图传递一些参数。

 

创建模板

index.html

{% extends ‘base.html‘ %}
{# 导入母板 #}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

</head>
<body>
    {% block content %} 
{#      content  内容,blog_list传过来的数据 #}
        {% for post in blog_list %}
            <h2>{{ post.title }}</h2>
            <p>{{ post.timestamp }}</p>
            <p>{{ post.body }}</p>
        {% endfor %}
    {% endblock %}
</body>
</html>

  

创建视图函数

views.py

#coding=utf-8
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() #获取数据库里面所拥有BlogPost对象
    return render_to_response(‘index.html‘,{‘blog_list‘:blog_list})
    #ender_to_response()返回一个页面(index.html),顺带把数据库中查询出来的所有博客内容(blog_list)也一并返回。

  

创建blog的URL模式    

urls.py   

from app1 import views
urlpatterns = [
    url(r‘^admin/‘, admin.site.urls),
    url(r‘^blog/‘,views.blog),
]

  

创建基础模板

templates目录里创建base.html的模板:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
         <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}
        p{margin:1em 0}
      </style>
</head>
<body>
<h1>孙其虎blog</h1>
    <h3>人生苦短,我学python</h3>
    {% block content %}
    {% endblock %}

</body>
</html>

  

修改index.html模板,让它引用base.html模板和它的“content”块。

 

{% extends ‘base.html‘ %}
{# 导入母板 #}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

</head>
<body>
    {% block content %}
{#      content  内容,blog_list传过来的数据 #}
        {% for post in blog_list %}
            <h2>{{ post.title }}</h2>
            <p>{{ post.timestamp }}</p>
            <p>{{ post.body }}</p>
        {% endfor %}
    {% endblock %}
</body>
</html>

  

 

技术分享

 

blog (后续更新)

原文:http://www.cnblogs.com/pythonxiaohu/p/5820263.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!