Django框架1——视图和URL配置

三个命令

1.创建一个django项目

在cmd中:django-admin.py startproject project_name

D:\python\django_site>django-admin startproject first_site

2.创建应用

python manage.py startapp app_name

D:\python\django_site\first_site>python manage.py startapp app001

3.运行django项目

python manage.py runserver 8999

D:\python\django_site\first_site>python manage.py runserver 8999

浏览器输入:127.0.0.1:8999就可以访问到django自带的欢迎页面

第一个视图

​ 创建一个基于Django的页面:Hellow World

​ 使用Django,页面的内容是靠view function(视图函数) 来产生,URL定
义在 URLconf 中。首先,我们先写一个Hello World视图函数。

views.py

from django.shortcuts import HttpResponse

# Create your views here.
import datetime
def first(request):
    return HttpResponse('Hellow World')

​ 每个视图函数至少要有一个参数,通常被叫作request。这是一个触发这个视图、包含当前Web请求信息的对象,是类django.http.HttpRequest的一个实例。在这个示例中,我们虽然不用request做任何事情,然而它仍必须是这个视图的第一个参数。


​ django‐admin.py startproject 时,该脚本会自动为你建了一份 URLconf(即 urls.py 文

件)。 默认的urls.py会像下面这个样子

urls.py

from django.contrib import admin
from django.urls import path
#添加:
from app001 import views
urlpatterns = [
    path('admin/', admin.site.urls),
    #添加:
    path('^first$/', views.first) #所有指向 URL /first/ 的请求都应由 first 这个视图函数来处理
]

​ 调用 path 函数并将返回结果保存到 urlpatterns 列表。在URLconf中加入URL和view,只需增加映射URL模式和view功能(添加path函数对象)

​ 运行命令行 python manage.py runserver 8999打开浏览器访问 http://127.0.0.1:8000/first/ 就可以查看输出结果

Django是怎么处理请求的

​ 当你通过在浏览器里敲http://127.0.0.1:8000/first/来访问Hello world消息得时候,Django在后台有些什么动作呢?
所有均开始于setting文件。当你运行python manage.py runserver,脚本将在于manage.py同一个目录下查找名为setting.py的文件。这个文件包含了所有有关这个Django项目的配置信息,均大写: TEMPLATE_DIRS, DATABASE_NAME , 等. 最重要的设置时ROOT_URLCONF,它将作为URLconf告诉Django在这个站点中那些Python的模块将被用到,创建的settings.py包含一个ROOT_URLCONF配置用来指向自动产生的urls.py. 打开文件settings.py你将看到如下:
​ ROOT_URLCONF = 'firt_site.urls'
相对应的文件是first_site/urls.py
​ 当访问 URL /first/ 时,Django 根据 ROOT_URLCONF 的设置装载 URLconf 。 然后按顺序逐个匹配URLconf里的URLpatterns,直到找到一个匹配的。 当找到这个匹配 的URLpatterns就调用相关联的view函数,并把HttpRequest 对象作为第一个参数。 正如我们在第一个视图例子里面看到的,一个视图功能必须返回一个HttpResponse。 一旦做完,Django将完成剩余的转换Python的对象到一个合适的带有HTTP头和body的Web Response(例如,网页内容)。
总结一下:

  1. 进来的请求转入/first/.
  2. Django通过在ROOT_URLCONF配置来决定根URLconf.
  3. Django在URLconf中的所有URL模式中,查找第一个匹配/hello/的条目。
  4. 如果找到匹配,将调用相应的视图函数
  5. 视图函数返回一个HttpResponse
  6. Django转换HttpResponse为一个适合的HTTP response, 以Web page显示出来

第二个视图:动态视图

在view.py增加下面代码

import datetime
def current_datetime(request):
	now = datetime.datetime.now().strftime('%Y-%m-%d')
	return HttpResponse(now)

在urls.py的urlpatterns列表中增加下面代码

path('time/', current_datetime)

URL配置和松耦合

​ 松耦合 原则。 简单的说,松耦合是一个 重要的保证互换性的软件开发方法。
​ Django的URL配置就是一个很好的例子。 在Django的应用程序中,URL的定义和视图函数之间是松 耦合的,换句话说,决定URL返回哪个视图函数和实现这个视图函数是在两个不同的地方。 这使得 开发人员可以修改一块而不会影响另一块。例如,考虑一下current_datetime视图。 如果我们想把它的URL 从原来的 /time/ 改变到 /currenttime/ ,我们只需要快速的修改一下URL配置即可, 不用担心这个函数的内部实现。 同样的,如果我们想要修改这个函数的内部实现也不用担心会影响 到对应的URL。

第三个视图:动态URL

在我们的 current_datetime 视图范例中,尽管内容是动态的,但是URL ( /time/ )是静态的。 在 大多数动态web应用程序,URL通常都包含有相关的参数。 举个例子,一家在线书店会为每一本书提供一个URL,如:/books/243/、/books/81196/。

/time/plus/1/ 显示当前时间+1个小时的页面 /time/plus/2/ 显示当前时间+2个小时的页面 /time/plus/3/ 显示当前时间+3个小时的页面,以此类推。

urlpatterns列表增加:

re_path(r'^time/plus/(\d+)/$', views.hour_ahead),

增加一个分组,对应的视图函数就需要增加一个参数

def hour_ahead(request,offset):
	dt = datetime.datetime.now()+datetime.timedelta(hours=int(offset))
    now = dt.strftime('%H:%M:%S')
	return HttpResponse(now)

这里命名变量为offset ,也可以任意命名它,只要符合Python 的语法。变量名是无关紧要的,重要的是它的位置,它是这个函数的第二个参数 (在request 的后面)。 还可以使用关键字来定义它,而不是用位置。对分组进行命名

from django.urls import path,re_path 
 #新版本2.2.6 路由使用path(),无需要无需用^和$,需要用到正则表达式使用re_path()
 #2.0之前使用url()
re_path(r'^time/plus/(?p<offset>\d+)/$', views.hour_ahead),
posted @ 2019-10-10 19:44  Sroxi  阅读(373)  评论(0编辑  收藏  举报