软件环境

Pycharm 2018.1

Python 3.6

Django 2.0.3

1、新建项目

直接使用Pycharm的菜单来创建项目,命名为mysite。

mysite

  mysite

    __init__.py

    settings.py

    urls.py

    wsgi.py

  templates

  manage.py

2、新建应用

使用Pycharm的tools菜单下的Run manage.py Task,在弹出的窗口中输入以下命令:

startapp blog

blog

  migrations

  __init__.py

  admin.py

  apps.py

  models.py

  tests.py

  views.py

3、将blog应用加到setting.py文件中的INSTALLED_APPS中

INSTALLED_APPS = [

  'blog',

]

4、编写第一个Model

编辑blog下的models.py文件,输入:

from django.db import models

class BlogPost(models.Model):
title = models.CharField(max_length=150)
body = models.TextField()
timestamp = models.DateTimeField() class Meta:
ordering = ['-timestamp']

5、设置数据库

一般使用默认的sqlite即可,也可以使用mysql。在settings.py中设置。

6、创建表

在Run manage.py Task中分别执行:

makemigrations

migrate

可以看到表被生成了。

7、创建超级用户(用于登录admin平台)

在Run manage.py Task中执行如下命令:

createsuperuser

依次输入用户名,邮箱,密码即可。

8、注册BlogPost应用

为了在admin管理平台上直接添加、删除文章,我们需要编辑admin.py文件:

from django.contrib import admin

from blog.models import BlogPost

class BlogPostAdmin(admin.ModelAdmin):
list_display = ['title', 'timestamp'] admin.site.register(BlogPost, BlogPostAdmin)

9、启动web服务器

访问http://127.0.0.1/admin

输入用户名密码即可。

10、创建博客的展示页面

在blog目录下新建templates目录,然后在templates目录下新建archive.html文件。

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

11、创建视图函数

from django.template import loader
from django.http import HttpResponse
from blog.models import BlogPost def archive(request):
posts = BlogPost.objects.all()
t = loader.get_template('archive.html')
return HttpResponse(t.render({'posts': posts}))

12、配置URL路径

先修改总URL文件:项目下的urls.py文件,与settings.py同级。

from django.contrib import admin
from django.urls import path, include urlpatterns = [
path('admin/', admin.site.urls),
path('blog/', include('blog.urls'))
]

然后修改子URL文件:应用blog下的urls.py文件,没有就新建,与views.py同级。

from blog.views import archive
from django.urls import path urlpatterns = [
path('', archive)
]

13、启动web服务器,查看效果

14、编写基础模板,让其他模板来继承

在templates下新建base.html文件,内容如下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<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>mysite.example.com</h1>
{% block content %}
{% endblock %}
</body>
</html>

15、重新修改archive.html文件

{% extends 'base.html' %}
{% block content %}
{% for post in posts %}
<h2>{{ post.title }}</h2>
<p>{{ post.timestamp}}</p>
<p>{{ post.body }}</p>
{% endfor %}
{% endblock %}

16、模板中的过滤器

<p>{{ post.timestamp | date }}</p>

管道后面通过date函数来进行过滤。

17、启动web服务器,检查效果

以上就是使用django开发web应用的一般流程。

Django基础流程的更多相关文章

  1. {Django基础九之中间件} 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证

    Django基础九之中间件 本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学会了 ...

  2. Django基础和基本使用

    Django基础 Django是Python下的一款著名的Web框架 框架 任何语言进入到高级部分时,会有认证.session.http.连接数据库等等功能操作,没有框架时需要自己实现 框架 是整个或 ...

  3. {Django基础八之cookie和session}一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session

    Django基础八之cookie和session 本节目录 一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session 六 xxx 七 ...

  4. Django基础之MTV模型

    一.Django基础 一.Django简介 Django是一个开放源代码的Web应用框架,由Python写成.采用了MVC的软件设计模式,即模型(Model).视图(View)和控制器(Control ...

  5. 【笔记】Django基础(一)

    ---恢复内容开始--- [笔记]Django基础(一) oldboy Django  一 关于Python框架的本质 1. HTTP协议消息的格式: 请求(request) 请求方法 路径 HTTP ...

  6. day 63 Django基础九之中间件

    Django基础九之中间件   本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学 ...

  7. day 52 Django基础一之web框架的本质

    Django基础一之web框架的本质   django第一天 本节目录 一 web框架的本质及自定义web框架 二 模板渲染JinJa2 三 MVC和MTV框架 四 Django的下载安装 五 基于D ...

  8. django基础(web框架,http协议,django安装)

    学习Django之前我们先来看什么是OSI七层模型: 应用层 表示层       应用层(五层模型中把这三层合成一个应用层) http协议 会话层 传输层                  提供端口对 ...

  9. Django基础知识点

    HTTP协议:  请求方式: 有8种分别是GET POST DELTE PUT OPTIONS HEAD 状态码: 2xx   200 OK 3xx   重定向 4xx   请求的错误 5xx   服 ...

随机推荐

  1. win10系统怎样手动安装cab更新补丁

    win10系统怎样手动安装cab更新补丁 1. 把所有补丁放进一个文件夹 例如 C:\UPDATE2. 以管理员运行命令提示符 3. 输入以下命令後按 Enterdism /online /add-p ...

  2. a标签上的点击事件

    当我们在处理a标签上的点击事件时发现即使href=""里面为空,点击事件的效果也不明显,这种情况该如何处理呢?常见的处理方法有以下几种: 1.a href="javasc ...

  3. PHP多线程处理问题

    近日工作中涉及到项目同时处理多个线程问题时,在网上找到了PHP的pthreads扩展以及curl_multi_init函数,具体如下: 一 .windows下安装php真正的多线程扩展pthreads ...

  4. WORD文档书签管理

    最近在浏览一个word超长文档,在文档中有几处要点用颜色做了标记,但是在下次查找的时候无法定位,还得一页页去翻,而且无法通过目录概览的形式查看总共做了多少处标记 于是想到了书签 原本以为在视图中能够设 ...

  5. Atitit.nosql api 标准化 以及nosql数据库的实现模型分类差异

    Atitit.nosql api 标准化 以及nosql数据库的实现模型分类差异 1. 常用的nosql数据库MongoDB  Cassandra1 1.1. 查询> db.blogposts. ...

  6. [容器]docker-ce安装最新版-docker常用操作

    社区: http://www.dockerinfo.net/rancher http://dockone.io/ https://www.kubernetes.org.cn/ 1,docker安装配置 ...

  7. Android JNI和NDK学习(05)--JNI真机调试(转)

    本文转自: http://www.cnblogs.com/skywang12345/archive/2013/05/23/3094250.html 本文主要介绍如何将JNI导入到真机进行调试.下面以M ...

  8. UML类图详解_泛化关系

    泛化其实就是继承关系,还是比较简单的,那么我们就把之前有些问题的博客UML类图重新来实现一次. 依旧是这个图 下面我们来看一个例子 Account.h #include <cstdlib> ...

  9. 基于GitLab的前端Assets发布体系

    以SVN+RMS为核心的发布系统,对前端开发的影响上来看,存在以下问题: 覆盖式的发布,容易导致线上问题. js一旦发布,就有可能被任意其他页面使用.被引用的越多,就越重要.一旦核心js出现故障,影响 ...

  10. 个人博客开发之xadmin与ueditor集成

    项目源码下载:http://download.vhosts.cn 1. xadmin 添加ueditor 插件 vim extra_apps\xadmin\plugins\ueditor.py #没有 ...