django1

1. 创建项目——在当前路径下创建了一个mysite目录

django-admin startproject mysite

2. 目录结构

|-- mysite
|   |-- __init__.py
|   |-- settings.py
|   |-- urls.py
|   `-- wsgi.py
`-- manage.py
  • 外部mysite/根目录:项目的容器。
  • manage.py:一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。
  • mysite/init.py:一个空文件,告诉 Python 该目录是一个 Python 包。
  • mysite/settings.py:该 Django 项目的设置/配置。
  • mysite/urls.py:该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。
  • mysite/wsgi.py:一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。

3. 运行服务器

python manage.py runserver 0.0.0.0:8000

让其它电脑可连接到开发服务器,8000 为端口号。如果不说明,那么端口号默认为 8000。
在浏览器输入你服务器的ip及端口号,如果正常启动,输出结果如下:

命令行内应该也有如下输出,证明启动无误:


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.
  • 不要在生产环境中使用此服务器。它仅用于开发时使用
  • 默认情况下,该runserver命令在端口8000的内部IP上启动开发服务器,要改变端口直接跟在命令最后即可,python manage.py runserver 8080
  • 如果要更改服务器的IP,请将其与端口一起传递,python manage.py runserver 0:8000

4. 创建 APP

执行python manage.py命令式请确定与manage.py在同一路径下)

python manage.py startapp myapp


项目与应用程序的关系

应用程序主要是负责执行操作,实现功能,类似博客里面的评论,登陆等等,而项目是特定网站的配置和应用程序的集合。项目可以包含多个应用程序。一个应用程序可以在多个项目中。执行应用创建命令之后会在当前路径下建立如下目录

|-- mysite
|   |-- __init__.py
|   |-- settings.py
|   |-- urls.py
|   `-- wsgi.py
|-- myapp
|   |-- __init__.py
|   |-- admin.py
|   |-- models.py
|   |-- tests.py
|   `-- views.py
`-- manage.py

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即可

你可能感兴趣的:(django1)