Django基础流程
软件环境:
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基础流程的更多相关文章
- {Django基础九之中间件} 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证
Django基础九之中间件 本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学会了 ...
- Django基础和基本使用
Django基础 Django是Python下的一款著名的Web框架 框架 任何语言进入到高级部分时,会有认证.session.http.连接数据库等等功能操作,没有框架时需要自己实现 框架 是整个或 ...
- {Django基础八之cookie和session}一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session
Django基础八之cookie和session 本节目录 一 会话跟踪 二 cookie 三 django中操作cookie 四 session 五 django中操作session 六 xxx 七 ...
- Django基础之MTV模型
一.Django基础 一.Django简介 Django是一个开放源代码的Web应用框架,由Python写成.采用了MVC的软件设计模式,即模型(Model).视图(View)和控制器(Control ...
- 【笔记】Django基础(一)
---恢复内容开始--- [笔记]Django基础(一) oldboy Django 一 关于Python框架的本质 1. HTTP协议消息的格式: 请求(request) 请求方法 路径 HTTP ...
- day 63 Django基础九之中间件
Django基础九之中间件 本节目录 一 前戏 二 中间件介绍 三 自定义中间件 四 中间件的执行流程 五 中间件版登陆认证 六 xxx 七 xxx 八 xxx 一 前戏 我们在前面的课程中已经学 ...
- day 52 Django基础一之web框架的本质
Django基础一之web框架的本质 django第一天 本节目录 一 web框架的本质及自定义web框架 二 模板渲染JinJa2 三 MVC和MTV框架 四 Django的下载安装 五 基于D ...
- django基础(web框架,http协议,django安装)
学习Django之前我们先来看什么是OSI七层模型: 应用层 表示层 应用层(五层模型中把这三层合成一个应用层) http协议 会话层 传输层 提供端口对 ...
- Django基础知识点
HTTP协议: 请求方式: 有8种分别是GET POST DELTE PUT OPTIONS HEAD 状态码: 2xx 200 OK 3xx 重定向 4xx 请求的错误 5xx 服 ...
随机推荐
- 基于STC12C5A的MINI3216多功能点阵时钟
代码地址如下:http://www.demodashi.com/demo/12862.html 基于STC12C5A的MINI3216多功能点阵时钟 硬件详解 PCB 硬件原理图 主控模块 max72 ...
- iOS 自定义转场动画浅谈
代码地址如下:http://www.demodashi.com/demo/11612.html 路漫漫其修远兮,吾将上下而求索 前记 想研究自定义转场动画很久了,时间就像海绵,挤一挤还是有的,花了差不 ...
- <转>c++ builder JSONCPP 注意事项 XE2 解决编译问题 _Mfl
在C++Builder中使用JSONCPP需要注意的问题 1.使用STL的MAP而不是内建的MAP这个问题实际上和编译器无关.内建的MAP不是很稳定,当解析数据大于600K左右时,会崩溃.虽然一般来说 ...
- 同时安装office2016与visio2016的实现过程
visio 2016安装问题 同时安装office2016与visio2016的实现过程 visio2016 but failed
- 工作总结 管理NuGet 程序包 中 找不到 npoi 怎么办
在设置里 勾选 可用程序包源
- 安装SDK后打开安卓project后有例如以下错误:发现了以元素 'd:skin' 开头的无效内容。此处不应含有子元素。
Error: Error parsing D:\Program Files\SDK\android-sdk-windows\system-images\android-22\android-wear\ ...
- 牛散NO.1:MACD计啜诱多,勾魂枪连环夺命时
上证日线“连环夺命勾魂枪” 话说MACD中圈C的回勾,好事者皆认为新的冲击波即将曙光再现.伴随着K线出现红柱中阳,更多的投资者将会被这一勾诱惑得群情亢奋,盲断行情又要 起来了.但往往事与愿违,“潘金莲 ...
- unity, 弹出panel一定要放在UI Hierarchy的底端
如上图,buyPanel放在最底端,为的是它弹出时屏蔽所有其它UI的消息.
- 分享我们必须知道的高速GTX技术
eSATA接口只有几根线为什么那么快?连上网线显示的1Gbps是不是很令人兴奋!没错他们都用了高速GTX技术,GTX全称为Gigabit Transceiver,是为了满足现代数字处理技术和计算技术庞 ...
- 初识Quartz(一)
首先需要一个任务: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 package quartz_proj ...