知识点
1) 创建项目命令
以及项目结构介绍
2) 创建应用程序命令
应用, 项目的区别
以及应用程序结构
3) 启动项目命令
4) URLs的编写
include()的使用
get发送参数的格式
url()的参数介绍
5) 最基本的视图函数的编写
1 创建项目
查看Django的版本
python -m django --version
创建项目命令为
django-admin startproject mysite
注意:
项目名不能和一些关键字重复, 如django或者test等
这个Python代码不要放在web服务器的文档根目录下, 因为这样容易被通过web查看到, 不够安全
创建之后的文件目录
mysite/
manage.py
mysite/
__init__.py
settings.py
urls.py
wsgi.py
对应的作用为
外部mysite/根目录: 只是一个项目的容器。它的名字与Django无关; 您可以将其重命名为任何您喜欢的内容
manage.py: 一个命令行实用程序,可以让您以各种方式与此Django项目进行交互
内部mysite/目录: 实际Python包。它的名字是您需要用于导入其中的任何内容的Python包名称(例如mysite.urls)
mysite/__init__.py: 一个空的文件,告诉Python这个目录应该被认为是一个Python包。
mysite/settings.py: 此Django项目的设置/配置。 Django设置会告诉你所有关于设置的工作原理。
mysite/urls.py: 该Django项目的URL声明; 您的Django动力网站的“目录”。
mysite/wsgi.py: WSGI兼容的Web服务器为您的项目提供服务的入口点。
2 运行服务器
python manage.py runserver
这是启动会绑定到
http://127.0.0.1:8000
指定端口
python manage.py runserver 8080
指定IP
python manage.py runserver 0:8000
其中0就是0.0.0.0的缩写, 表示监听所有公共的IP
注意:
一般的, 修改项目中的代码服务器会自动重启使得这个更改的代码生效(重启完毕能看到提示)
但是有的动作(例如: 添加文件)不会自动触发重新启动服务器, 这要注意
3 创建Polls app
项目(project): 特定网站的配置和应用程序的集合
应用程序(apps): An app is a Web application that does something
项目可以包含多个应用程序, 一个应用程序可以在多个项目中
可以通过命令来生成一个应用程序
一般地: 创建的应用程序可以放在任何位置, 但是由于放在顶级文件夹(外部mysite/根目录下)的时候更加方便导入, 一般不随意放置
创建应用程序命令
python manage.py startapp polls
得到的目录为
polls/
__init__.py
admin.py
apps.py
migrations/
__init__.py
models.py
tests.py
views.py
4 编写视图
polls/views.py
from django.http import HttpResponse
def index(request):
return HttpResponse("Hello, world. You're at the polls index.")
要是视图生效, 需要编写URLconf
因此在polls/ 下创建一个urls.py文件, 由此, 现有的结构为
polls/
__init__.py
admin.py
apps.py
migrations/
__init__.py
models.py
tests.py
urls.py
views.py
polls/urls.py
from django.conf.urls import url
from polls import views
urlpatterns = [
url(r'^$', views.index, name='index'),
]
然后需要修改 根URLconf(mysite/urls.py) 让它执行 当前编写的 polls/urls.py
mysite/urls.py
from django.conf.urls import include, url
from django.contrib import admin
urlpatterns = [
url(r'^polls/', include('polls.urls')),
url(r'^admin/', admin.site.urls),
]
include()函数可以引用其他的URLconfs
注意:
the regular expressions for the include() function doesn’t have a $ (end-of-string match character) but rather a trailing slash
include()函数使得URLs的即插即用变得可行
官方强力推荐使用include()的方式来编写URLs, 当然自带的admin.site.urls是唯一的例外
5 url()的参数
url()可以接受4个参数
def url(regex, view, kwargs=None, name=None):
pass
其中regex和view是必选参数, kwargs和name是可选参数
1) url() argument: regex
该参数是用于匹配URLs的, Django会从上到下依次匹配这些正则表达式
当然, 匹配的时候会忽略域名和GET和POST的参数
https://www.example.com/myapp/
查找
/myapp/
https://www.example.com/myapp/?page=3
查找
/myapp/
get发送参数的格式为:
URL?参数名=参数值&参数名2=参数2值...
注意:
这些正则表达式会在第一次加载URLconf的时候编译, 一般来说速度都很快
但是这个正则匹配不要写的太过于复杂, 这样会影响性能
2) url() argument: view
当url满足正则表达式的时候, 就会调用对应的view函数
会传入两种参数
HttpResquest对象
正则表达式捕获的值
正则表达式捕获的值分为两种
简单捕获, 作为位置参数传递
命名捕获, 作为关键字参数传递
3) url()参数:kwargs
传递关键字参数传递给视图函数, 形式是字典
4) url() argument: name
命名该URL
通过这个名字, 可以在视图函数, 模板文件中获取该URL