django笔记--1

安装django

  • 安装

python -m pip install django -m 即 python 以脚本的方式执行后面的模块,用pip来直接安装django
官方文档

  • 验证

python -m django --version 查看下是否显示django版本信息,如果报错说没有这个模块就证明没有安装成功。


开始一个项目

注意:项目和应用是不一样的概念,一个项目可能有n个应用(app)
用django-admin 的 startproject 创建一个项目
django-admin startproject mysite . mysite 是你的项目名称,后面的点号是一个小技巧,即当前目录放置目录嵌套好多,造成项目结构混乱。

  • startproject 会自动创建一些文件
mysite/
    manage.py
    mysite/
        __init__.py
        settings.py
        urls.py
        asgi.py
        wsgi.py
  1. 最外层的 mysite/ 根目录只是你项目的容器, 根目录名称对Django没有影响,你可以将它重命名为任何你喜欢的名称。
  2. manage.py: 一个让你用各种方式管理 Django 项目的命令行工具。
  3. 里面一层的 mysite/ 目录包含你的项目,它是一个纯 Python 包。它的名字就是当你引用它内部任何东西时需要用到的 Python 包名。 (比如 mysite.urls).
  4. mysite/init.py:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。
  5. mysite/settings.py:Django 项目的配置文件。
  6. mysite/urls.py:Django 项目的 URL 声明,就像你网站的“目录”。
  7. mysite/asgi.py:作为你的项目的运行在 ASGI 兼容的Web服务器上的入口。
  8. mysite/wsgi.py:作为你的项目的运行在 WSGI 兼容的Web服务器上的入口。

用自带的简易服务器查看效果

cd 到项目的根目录,然后运行:
python manage.py runserver 8080 后面的8080是指定端口号,如果不写默认端口号为8000
来打开自带的简易服务器,然后就可以通过
127.0.0.1:8080 来查看效果。


  • 项目已经创建完成,可以在项目下创建应用了

创建投票应用

python manage.py startapp polls 后面的polls是应用的名称

自动创建的目录结构大致为:

polls/
    __init__.py
    admin.py
    apps.py
    migrations/
        __init__.py
    models.py
    tests.py
    views.py
  • views.py文件控制该应用里面的视图

在polls/views.py文件编辑入下,最简单的视图:

from django.http import HttpResponse


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

如果想看见效果,我们需要将一个 URL 映射到它——这就是我们需要 URLconf 的原因了。
为了创建 URLconf,请在 polls 目录里新建一个 urls.py 文件。
在 polls/urls.py 中,输入如下代码:

from django.urls import path

from . import views

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

下一步是要在根 URLconf 文件中指定我们创建的 polls.urls 模块。在 mysite/urls.py 文件的 urlpatterns 列表里插入一个 include(), 如下:

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

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

函数 include() 允许引用其它 URLconfs。每当 Django 遇到 include() 时,它会截断与此项匹配的 URL 的部分,并将剩余的字符串发送到 URLconf 以供进一步处理。

我们设计 include() 的理念是使其可以即插即用。因为投票应用有它自己的 URLconf( polls/urls.py ),他们能够被放在 "/polls/" , "/fun_polls/" ,"/content/polls/",或者其他任何路径下,这个应用都能够正常工作。

你现在把 index 视图添加进了 URLconf。通过以下命令验证是否正常工作:

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


函数 path() 具有四个参数

  1. 两个必须参数:route 和 view
  2. 两个可选参数:kwargs 和 name。
  • 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 模式。

2020.12.8
hare

posted @ 2020-12-08 11:06  hare1925  阅读(64)  评论(0编辑  收藏  举报