Django:快速搭建简单的Blog

时间:2021-07-08 09:40:09

一,创建项目

1, 为blog创建名为mysite的工程项目:

 django-admin.py startproject mysite

2, 项目结构如下:

  mysite
├── manage.py
└── mysite
├── __init__.py
├── settings.py
├── urls.py
└── wsgi.py
  • manage.py ----- Django项目里面的工具,通过它可以调用django shell和数据库等。

  • settings.py ---- 包含了项目的默认设置,包括数据库信息,调试志以及其他一些工作的变量。

  • urls.py ----- 负责把URL模式射到应用程序。

二 ,运行开发服务器

要马上查看django项目应用的运行,可以使用Django项目里的mange.py

切换到工程目录,执行运行服务器命令:

python manage.py runserver

完成:

Django:快速搭建简单的Blog

打开浏览器,输入访问地址:127.0.0.1:8000

Django:快速搭建简单的Blog

三,创建Blog应用

python manage.py startapp blog

blog应用文件结构如下:

├── blog
│ ├── admin.py
│ ├── __init__.py
│ ├── models.py
│ ├── tests.py
│ └── views.py

四,设计的Model

在blog目录下的models.py是blog应用的心文件之一,是定义blog数据结构的地方。

用编辑器打开models.py

新添BlogPost类,代如下:

from django.db import models

# Create your models here.
class BlogPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField()

BlogPost类是django.db.models.Model的一个子类 。它有变量title(blog的题),body(blog的内容部分),timestamp(blog的发表时间)。

五,设置数据库

Dajango支持主流的数据库服务器(MySQL,PostgreSQL,Oracle和MSSQL),但本项目使用SQLite,这里之需要通过一条简单的命令可以创建SQLite数据库。

创建数据库:

切换到工程主目录mysite/下,执行如下命令:

<span ><span >python manage.py syncdb<br></span></span>

出现下面的提示,输入yes,然后按照提示输入相关的信息。完成后会生成一个数据库文件db.sqlite3

Django:快速搭建简单的Blog

六,设置自动admin应用

1,打开mysite/mysite/urls.py,取消注释url(r'^admin/', include(admin.site.urls))

2,编辑mysite/mysite/settings.py,在INSTALLED_APPS里面添blog应用。

添后的代如下:

<span ><span ># Application definition INSTALLED_APPS = (    'django.contrib.admin',    'django.contrib.auth',    'django.contrib.contenttypes',    'django.contrib.sessions',    'django.contrib.messages',    'django.contrib.staticfiles',    'blog', )<br></span></span>

2,修改mysite/blog/models.py

在最后添一行代:

<span ><span >admin.site.register(BlogPost)<br></span></span>

models.py完整的代如下:

from django.db import models
from django.contrib import admin # Create your models here.
class BlogPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField() admin.site.register(BlogPost)

3 ,打开浏览器,输入http://127.0.0.1:8000/admin/,输入刚才创建数据库时候填写的帐号就能进入admin界面。

Django:快速搭建简单的Blog

Django:快速搭建简单的Blog

七,试用admin

1, 点击Blog Posts右侧的Add 按钮,添一个帖子。

Django:快速搭建简单的Blog

2,让admin的BlogPost界面更美观

修改blog应用的models.py,为它添一个admin.ModelAdmin的子类BlogPostAdmin.以列表形式显示BlogPost的题和时间。

from django.db import models
from django.contrib import admin # Create your models here.
class BlogPost(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(BlogPost,BlogPostAdmin)

Django:快速搭建简单的Blog

八,建立Blog的公共部分

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

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

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

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

1,创建模板

在blog目录下建立template目录(mysite/blog/templates),创建模板文件archive.html,它的内容如下:

{% for post in posts %}
<h2>{{ post.title }}</h2>
<p>{{ post.timestamp }}</p>
<p>{{ post.body }}</p>
{% endfor%}

2,创建一个视图函数

在app应用的目录下的view.py添视图函数

from django.shortcuts import render
from django.template import loader,Context
from django.http import HttpResponse
from blog.models import BlogPost # Create your views here. def archive(request):
posts = BlogPost.objects.all()
t = loader.get_template("archive.html")
c = Context({'posts':posts})
return HttpResponse(t.render(c))
  • posts = BlogPost.objects.all() :获取数据库里面所拥有BlogPost对象

  • t = loader.get_template("archive.html"):载模板

  • c = Context({'posts':posts}):模板的渲染的数据是有一个字典类的对象Context提供,这里的是一对键值对。

3,创建一个URL模式

第一步,在mysite/urls.py里面取消下面的一行注释:

#

把它变成:

url(r'^blog/', include('blog.urls')),

第二步:在blog应用里面定义URL,创建一个urls.py(mysite/blog/urls.py)

from django.conf.urls import *
from blog.views import archive urlpatterns = patterns('',
url(r'^$',archive),
)

最后,在浏览器输入如下地址http://127.0.0.1:8000/blog/

Django:快速搭建简单的Blog

九,最后的润色

1,模板的精确定位

在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}
p{margin:1em 0}
</style> <body>
<h1>my blog</h1>
{% block content %}
{% endblock %}
</body>
</html>

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

  {% extends "base.html" %}
{% block content %}
{% for post in posts %}
<h2>{{ post.title }}</h2>
<p>{{ post.timestamp | date:"1,F jS"}}</p>
<p>{{ post.body }}</p>
{% endfor %}
{% endblock %}

刷新浏览器可以看到效果如下:

Django:快速搭建简单的Blog

3,按日期排序

修改blog 应用下的models.py,为BlogPost添一个Meta嵌套类。如下:

<span >class BlogPost(models.Model):
title = models.CharField(max_length = 150)
body = models.TextField()
timestamp = models.DateTimeField() class Meta:
ordering = ('-timestamp',)<br></span>

刷新浏览器,如下:

Django:快速搭建简单的Blog

文章出处: 开源中国 
文章地址: http://my.oschina.net/matrixchan/blog/184445 
本文地址: http://www.webrube.com/django-python-web_rube/2057 
本文由 噜吧 整理,转载请保留以上信息; 如有侵犯您的版权, 请联系微信: 3715397 。

Django:快速搭建简单的Blog的更多相关文章

  1. 使用Django快速搭建简单的数据管理后台

    使用Django快速搭建简单的数据管理后台 概述 需求描述: 数据表已建好,能可视化操作增删改查,避免直接操作数据库 简版的管理系统 环境 Windows 10 x64 Python 3.6.3 (A ...

  2. 拿nodejs快速搭建简单Oauth认证和restful API server攻略

    拿nodejs快速搭建简单Oauth认证和restful API server攻略:http://blog.csdn.net/zhaoweitco/article/details/21708955 最 ...

  3. Django快速搭建博客系统

    Django快速搭建博客系统 一.开发环境 Windows 7(64bit) python 3.6   https://www.python.org/ Django 2.0  https://www. ...

  4. django 快速搭建blog

    如果本文看不懂的,去看的我视频吧!http://www.testpub.cn/ ------------------------------------------- Django 自称是“最适合开发 ...

  5. django 快速搭建blog(三)

    http://www.cnblogs.com/fnng/p/3737964.html 引用自此博客 创建blog的公共部分 从Django的角度看, 一个页面 具有三个典型的组件: 一个模板(temp ...

  6. django快速搭建blog

    python版本:3.5.4: Django版本:2.0 创建项目 创建mysite项目和 blog应用: django-admin startproject mysite # 创建mysite项目 ...

  7. 使用Node&period;js快速搭建简单的静态文件服务器

    做前端有时会采用一些复杂框架,在文件系统中直接打开页面(用file:///方式打开),往往会报跨域的错,类似于“XMLHttpRequest cannot load ...(文件名). Cross o ...

  8. Django创建一个简单的blog

    1. 使用django-admin.py 创建mysite项目 sunny@sunny-ThinkPad-T450:~/PycharmProjects$ django-admin.py startpr ...

  9. 用pytorch1&period;0快速搭建简单的神经网络

    用pytorch1.0搭建简单的神经网络 import torch import torch.nn.functional as F # 包含激励函数 # 建立神经网络 # 先定义所有的层属性(__in ...

随机推荐

  1. POJ 3311 Hie with the Pie &lpar;状压DP&rpar;

    dp[i][j][k] i代表此层用的状态序号 j上一层用的状态序号 k是层数&1(滚动数组) 标准流程 先预处理出所有合法数据存在status里 然后独立处理第一层 然后根据前一层的max推 ...

  2. Unieap3&period;5-Grid翻页不提示修改

    <toolbar export="{defaultType:'server'}" paging="{onPagingModified:ssSettleCheck.o ...

  3. &lbrack;转&rsqb;Form中控制Tab画布不同标签间切换的方法

    转自:http://yedward.net/?id=68 Form中一般常用的画布类型包括content.stacked.tab这三种,其实content类型的画布是每一个form都必须有的,而且只能 ...

  4. Swift - 给表格UITableView添加索引功能(快速定位)

    像iOS中的通讯录,通过点击联系人表格右侧的字母索引,我们可以快速定位到以该字母为首字母的联系人分组.   要实现索引,我们只需要两步操作: (1)实现索引数据源代理方法 (2)响应点击索引触发的代理 ...

  5. VS2010程序打包操作

    摘录:http://www.cnblogs.com/daban/archive/2012/06/27/2565449.html   1.  在vs2010 选择“新建项目”----“其他项目类型”-- ...

  6. Cisco VPN Client Error 56解决

    Cisco VPN Client Error 56解决 VPN Client报错 650) this.width=650;" style="width:575px;height:1 ...

  7. java 11 实现RFC7539中指定的ChaCha20和Poly1305两种加密算法&comma; 代替RC4

    实现 RFC 7539的ChaCha20 and ChaCha20-Poly1305加密算法 RFC7748定义的秘钥协商方案更高效, 更安全. JDK增加两个新的接口 XECPublicKey 和 ...

  8. JAVA实现接口监控报警系统

    公司一内部系统需要添加一个接口和定时任务监控机制,针对了系统出现的定时任务没有执行,定时任务执行异常出错,对外传送的数据接口异常出错,对内的系统数据互传异常出错等问题进行设计,目的是为了能够让用户没发 ...

  9. javascript替代Array&period;prototype&period;some操作

    Array.prototype.some在低版本浏览器好像不太兼容,下列是替代方法 一. for 循环 const initIds: any[] = [1,2,3]; const Ids: any[] ...

  10. linux yum&plus;wget详解

    在做自动化测试的时候,有个test需要执行命令:wget http://www.aliyun.com,但是返回的结果是未找到命令wget,于是百度了相关资料,发现没有安装wget,于是利用yum in ...