安装与配置
此过程参考官方文档
新建项目
在存放代码的目录启动终端或命令行,输入:
1 | $ django-admin startproject HelloWorld |
该命令会建立一个HelloWorld文件夹并初始化这个项目
目录结构如下:
1
2
3
4
5
6
7 HelloWorld/
├── HelloWorld
│ ├── __init__.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
└── manage.py
- HelloWorld # 项目根目录
- HelloWord # 项目初始化的包
- __init__.py # 空文件,说明这是一个包
- settings.py # 项目配置文件
- urls.py #声明请求url的映射关系
- wsgi.py # python程序和web服务器的通信协议
- manage.py # 一个命令行工具,用来和Django项目进行交互
- HelloWord # 项目初始化的包
App的概念
我们来看看settings.py里的内容
1 | import os |
这些英语应该都不难,我们要引入一个App的概念:
假设要搭建一个博客平台,那么文章管理、评论管理、搜索引擎……这些不同的业务可以视为不同的App。
新建App
新建一个名叫demo的app的操作:<先进入到项目文件夹里>
1 | $ python manage.py startapp demo |
再看看目录:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18 >├── demo
>│ ├── __init__.py
>│ ├── admin.py
>│ ├── apps.py
>│ ├── migrations
>│ │ └── __init__.py
>│ ├── models.py
>│ ├── tests.py
>│ └── views.py
>├── HelloWorld
>│ ├── __init__.py
>│ ├── __pycache__
>│ │ ├── __init__.cpython-36.pyc
>│ │ └── settings.cpython-36.pyc
>│ ├── settings.py
>│ ├── urls.py
>│ └── wsgi.py
>└── manage.pyadmin.py # 对应应用后台管理配置文件
apps.py # 对应应用的配置文件
models.py # 数据模块,用于设计数据库等
tests.py # 编写测试脚本
views # 视图层,直接和浏览器进行交互
注册App
在settings.py中添加:
1 | INSTALLED_APPS = [ |
把刚刚新建的App添加进去
Coding
views.py
1 | """ |
然后添加映射
1 | from django.contrib import admin |
在urlpatterns中加入url(‘hello/‘, views.hello),第一个元素是匹配的字符串,第二个元素为相对应的视图模块。
也就是告诉django所有url/hello/ 的请求都是指向了views.hello 这个视图。hello前不需要加’/‘,因为域名的末尾一定会有’/‘。其中’^’为严格前匹配,浏览器输入http://localhost:8000/hello/a/b 也是可以访问view.hello视图
启动项目
1 | $ python manage.py runserver |