美文网首页
编写你的第一个 Django 应用

编写你的第一个 Django 应用

作者: 南风逸梦 | 来源:发表于2019-05-18 21:37 被阅读0次

环境

  • 系统:win10
  • python: 3.6.3
  • django:2.1.7

查看python版本
python
查看django版本
python -m django --version

创建项目

创建django项目
django-admin startproject firstDjango
生成如下目录

firstDjango/
    manage.py
    db.sqlite3
    firstDjango/
        __init__.py
        settings.py
        urls.py
        wsgi.py

这些目录和文件的用处是:

  • 最外层的 firstDjango/ 根目录只是你项目的容器, Django 不关心它的名字,你可以将它重命名为任何你喜欢的名字。
  • manage.py: 一个让你用各种方式管理 Django 项目的命令行工具。你可以阅读 django-admin and manage.py 获取所有 manage.py 的细节。
  • 里面一层的 firstDjango/ 目录包含你的项目,它是一个纯 Python 包。它的名字就是当你引用它内部任何东西时需要用到的 Python 包名。 (比如 firstDjango.urls).
  • firstDjango/__init__.py:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。如果你是 Python 初学者,阅读官方文档中的 更多关于包的知识
  • firstDjango/settings.py:Django 项目的配置文件。如果你想知道这个文件是如何工作的,请查看 Django settings 了解细节。
  • firstDjango/urls.py:Django 项目的 URL 声明,就像你网站的“目录”。阅读 URL调度器 文档来获取更多关于 URL 的内容。
  • firstDjango/wsgi.py:作为你的项目的运行在 WSGI 兼容的Web服务器上的入口。阅读 如何使用 WSGI 进行部署 了解更多细节。

cd 进入项目
cd firstDjango
运行
python manage.py runserver
得到如下输出:

image.png
浏览器访问 https://127.0.0.1:8000/,可以看到如下页面。
image.png

创建应用

接下来创建第一个应用
Ctrl+c 停止运行django项目,然后创建一个应用
python manage.py startapp firstApp

这将会创建一个 firstApp目录,它的目录结构大致如下:

firstApp/
    __init__.py
    admin.py
    apps.py
    migrations/
        __init__.py
    models.py
    tests.py
    views.py

start coding

接下来开始编写第一个视图,打开 firstApp/views.py,把下面这些 Python 代码输入进去:

from django.http import HttpResponse

def index(request):
    return HttpResponse("Hello, world. You're at the polls index.")
image.png

接下来在 firstApp 目录里新建一个 urls.py 文件。你的应用目录现在看起来应该是这样:

firstApp/
    __init__.py
    admin.py
    apps.py
    migrations/
        __init__.py
    models.py
    tests.py
    urls.py
    views.py

firstApp /urls.py 中,输入如下代码:

from django.urls import path

from . import views

urlpatterns = [
    path('', views.index, name='index'),
]

在 firstDjango/urls.py 文件的 urlpatterns 列表里插入一个 include(),引入刚才在firstApp中创建的urls

from django.contrib import admin
from django.urls import include, path

urlpatterns = [
    path('firstapp/', include('firstApp.urls')),
    path('admin/', admin.site.urls),
]

python manage.py runserver运行一下,
用你的浏览器访问 http://localhost:8000/polls/,你应该能够看见 "Hello, world. You're at the polls index." ,这是你在 views.pyindex 视图中定义的响应(HttpResponse)。

image.png

注意不是http://localhost:8000/哦,此时这个页面会有个错误。

path()

函数 path() 具有四个参数,两个必须参数:routeview,两个可选参数:kwargsname

path() 参数: route

route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项。

这些准则不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 https://www.example.com/myapp/ 时,它会尝试匹配 myapp/ 。处理请求 https://www.example.com/myapp/?page=3 时,也只会尝试匹配 myapp/

path() 参数: view

当 Django 找到了一个匹配的准则,就会调用这个特定的视图函数,并传入一个 HttpRequest 对象作为第一个参数,被“捕获”的参数以关键字参数的形式传入。稍后,我们会给出一个例子。

path() 参数: kwargs

任意个关键字参数可以作为一个字典传递给目标视图函数。本教程中不会使用这一特性。

path() 参数: name

为你的 URL 取名能使你在 Django 的任意地方唯一地引用它,尤其是在模板中。这个有用的特性允许你只改一个文件就能全局地修改某个 URL 模式。

相关文章

网友评论

      本文标题:编写你的第一个 Django 应用

      本文链接:https://www.haomeiwen.com/subject/forxzqtx.html