之前的学习过程中一直是冲着项目去板块化学习,忽略了很多基础的东西,反而项目过程中会遇到很多问题,开发过程中也是会很多去参考其他人的代码,所以这里重新把文档学一遍并将过程中的笔记记录下来
1. 创建项目——在当前路径下创建了一个mysite目录
django-admin startproject mysite
2. 目录结构
image.png-
外部
mysite/
根目录只是项目的容器。它的名字对Django来说无关紧要; 你可以将它重命名为你喜欢的任何东西。 - manage.py:一个命令行实用程序,允许您以各种方式与此Django项目进行交互,用作项目执行。
-
内部mysite/目录是项目的实际Python包。它的名称是您需要用来导入其中任何内容的Python包名称(例如
mysite.urls
)。 - mysite/init.py:一个空文件,告诉Python该目录应该被视为Python包。如果您是Python初学者,请阅读官方Python文档中有关包的更多信息。
- mysite/settings.py:此Django项目的设置/配置。 Django设置将告诉您有关设置如何工作的所有信息。
- mysite/urls.py:这个Django项目的URL声明; 您的Django支持的站点的“目录”,可以在这里声明网页访问路径,您可以在URL调度程序中阅读有关URL的更多信息。
- mysite/wsgi.py:与WSGI兼容的Web服务器的入口点,用于为您的项目提供服务。有关更多详细信息,请参阅如何使用WSGI进行部署。
3. 运行服务器
python manage.py runserver
之后就可以去网页上面看到反馈信息,无非是一些版本信息,可以在settings.py里面做修改,命令行内应该也有如下输出,证明启动无误:
System check identified no issues (0 silenced).
You have unapplied migrations; your app may not work properly until they are applied.
Run 'python manage.py migrate' to apply them.
January 11, 2019 - 15:50:53
Django version 2.1, using settings 'mysite.settings'
Starting development server at [http://127.0.0.1:8000/](http://127.0.0.1:8000/)
Quit the server with CONTROL-C.</pre>
- 不要在生产环境中使用此服务器。它仅用于开发时使用
- 默认情况下,该
runserver
命令在端口8000的内部IP上启动开发服务器,要改变端口直接跟在命令最后即可,python manage.py runserver 8080 - 如果要更改服务器的IP,请将其与端口一起传递,
python manage.py runserver 0:8000
4. 创建应用(执行python manage.py命令式请确定与manage.py在同一路径下)
python manage.py startapp polls
项目与应用程序的关系
image.png应用程序主要是负责执行操作,实现功能,类似博客里面的评论,登陆等等,而项目是特定网站的配置和应用程序的集合。项目可以包含多个应用程序。一个应用程序可以在多个项目中。执行应用创建命令之后会在当前路径下建立如下目录
5. 应用结构
i. 视图
这里从单词就能看出来作用,类似MVC里面的views,主要是与页面视图相关的逻辑代码,并返回数据给页面使用
from django.http import HttpResponse
def index(request):
return HttpResponse("Hello, world. You're at the polls index.")
- HttpResponse是系统http模块方法,可通过它直接返回字符串,返回页面更多的使用render函数
ii. URL映射
要调用视图,我们需要将其映射到URL
这里的映射配置一般写在urls.py里面,可以直接写在大项目目录下的urls.py里面,但是为了区分不同应用间的功能,我们往往会在每个应用中独立出一个urls.py配置文件(配置类似,可以直接复制过去更改相应path),在最外部项目下面的urls.py里面调用include方法配置即可
这里配置好应用的urls之后我们去项目配置中设置URLconfig指向,这里需要导入include方法,该
include()
函数允许引用其他URLconf。每当Django遇到时include()
,它都会删除与该点匹配的URL的任何部分,并将剩余的字符串发送到包含的URLconf以进行进一步处理。
urls里面关于path的设置涉及四个参数,两个必需: route和view,以及两个可选:kwargs,和name。
route: route(路由)是一个包含URL模式的字符串。访问时请求的路径,处理请求时,Django从第一个模式开始urlpatterns并沿着列表向下移动,将请求的URL与每个模式进行比较,直到找到匹配的模式。这里不会对请求方法(GET/POST)进行区分
view: 当Django找到匹配的模式时,它调用指定的视图函数,其中一个HttpRequest
对象作为第一个参数,并且路由中的任何“捕获”值作为关键字参数。相当于传递一个视图函数中的方法,我们稍后会给出一个例子。
kwargs: 任意关键字参数可以在字典中传递到目标视图。我们不打算在教程中使用Django的这个功能(目前用处不多)
name: 命名您的URL可以让您从Django的其他地方明确地引用它,特别是在模板中。此强大功能允许您在只触摸单个文件的同时对项目的URL模式进行全局更改。相当于是给你调用的视图函数起一个名字,之后在返回的模板页面里面方便调用
polls/的urls.py
from django.urls import path
from . import views
urlpatterns = [
path('', views.index, name='index'),
]
mysite/的urls.py
from django.contrib import admin
from django.urls import include, path
urlpatterns = [
path('polls/', include('polls.urls')),
path('admin/', admin.site.urls),
]
至此我们已经完成了第一个Django项目的第一部分,可以执行服务器然后去页面看一下效果,应该就是你视图函数里面编写的字符串内容,记得安装创建的应用哦
- 应用创建并且编写好视图函数以及urls等配置时记得去settings里面安装应用,将应用名字添加进INSTALLED_APPS即可
网友评论