Django来敲门~第一部分【6.1 视图函数】

治大国若烹小鲜。以道莅天下 ——老子《道德经》


本节内容

  • Django web项目的运行流程分析
  • 视图处理函数的定义
  • 多视图处理函数及接收参数

1. web项目运行流程分析

通常情况下,完整的处理流程如下:

  • 浏览器发起请求(浏览器:大爷,我需要http://localhost:8000/polls这个资源,给我吧);
  • 服务器接收到用户请求,开始分析这个URL地址(服务器:介个家伙要什么东东啊,掐掉URL默认的头部http://localhost:8000,剩下的就是要访问的东东了,原来是要访问:polls/
  • 服务器urls.py模块处理路由(服务器:来来来,来我的mysite/urls.py中看看,有木有和你要的东东类似的,找啊找啊找啊找找到一个`r"^polls/"`,就是它了,它是谁呢原来是隔壁老王啊include("polls.url")
  • 服务器urls.py继续查找include包含的下一级路由(服务器:隔壁老王,这个家伙要申请polls/里面的东东,你看看你家有木有这个东东,此时掐掉开头的"polls/",开始查找""(找的是一个空白字符), polls/urls.py的内容,找啊找啊找啊找~找到一个url(r"^$"),对应的就是views.index处理函数了)
  • 服务器处理视图的函数(服务器:老王说在我家床上有个views视图里面有个index处理函数,就是它了,然后将床单index函数处理的结果,扔给了浏览器去展示了)

看到这里是不是已经晕菜了,这就对了,接下来,看一张图,就明白了

请求的处理过程 接下来,我们的重点就是视图处理函数

2. 视图处理函数的定义

在我们创建好的应用polls/中,可以定义视图函数,专门用于接收和响应URL请求操作的函数; 该函数默认第一个参数接收的就是一个请求对象HttpRequest,通常我们会将第一个参数写成request;函数后面的其他参数就是可以从URL路径中接收的参数数据了。

接下来,先看我们之前定义的视图处理函数如下:

  • 第一个视图函数的定义和配置,修改mysite/polls/views.py文件如下
from django.http import HttpResponse
# 访问应用首页
def index(request):
    return HttpResponse("Hello Django!")

polls/urls.py中添加路由配置

import django.conf.urls import url
from . import views
# 配置路由操作
urlpatterns = [
    url(r"^$", views.index, name="index")
]

mysite/mysite/urls.py中将应用中的路由文件包含进去

urlpatterns = [
    url(r"^admin/", admin.site.urls),
    url(r"^polls/", include("polls.urls"))
]

OK,配置结束,此时就可以在浏览器中直接访问我们的应用了 python3 manage.py runserver启动项目 浏览器中访问:http://localhost:8000/polls就OK了

3.多视图处理函数及接收参数

接下来,我们定义多个视图处理函数,并定义接收的参数

修改polls/views.py文件,添加如下的几个视图函数

import django.http import HttpResponse
import .models import Question

# 首页视图处理函数
def index(request):
    # 查询所有的问题
    question_list = Question.object.order_by("-pub_date")
    # 拼接所有的问题
    output = ", ".join([q.question_text for q in question_list])
    # 返回视图
    return HttpResponse(output)

# 定义问题详情视图
def detail(request, question_id):
    # 根据主键查询一个问题对象
    question = Question.objects.get(pk=question_id)
    # 返回视图
    return HttpResponse("你要查看编号为<%s>的问题是:%s" % (question_id, question.question_text))

# 定义结果视图
def result(request, question_id):
    # 直接返回一个视图
    return HttpResponse("您正在查看编号为<%s>的问题的结果" % question_id)

# 定义投票处理
def vote(request, question_id):
    # 直接返回一个视图
    return HttpResponse("您准备给编号为<%s>的问题投票吗" % question_id)

接下来,修改polls/urls.py路由配置文件

from django.conf.urls import url

urlpatterns = [
     url(r"^$", views.index, name="index"),
     url(r"^(?P<question_id>\d+)$", views.detail, name="detail"),
     url(r"^(?P<question_id>\d+)/results/$", views.results, name="results"),
     url(r"^(?P<question_id>\d+)/vote/$", views.vote, name="vote"),
]

OK,多个视图的处理函数就配置完成了,访问模式如下

浏览器请求:http://localhost:8000/polls/
处理函数:index
浏览器请求:http://localhost:8000/polls/1
处理函数:detail
浏览器请求:http://localhost:8000/polls/1/results
处理函数:results
浏览器请求:http://localhost:8000/2/vote
处理函数:vote

大家可以自己试试哦~~

未完待续,下一节,将会是里程碑的一节内容,HTML页面会出现在我们的web项目中


本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Jerry的SAP技术分享

如何找到SAP Cloud for Customer标准培训和认证方面的信息

有一些朋友询问我如何在SAP官网上找到和SAP Cloud for Customer相关的标准培训信息,我这里把步骤写出来:

11210
来自专栏BeJavaGod

RabbitMQ 一二事(2) - 工作队列使用

上篇文章讲了简单队列的使用,这其实就是RMQ给的demo,实际并没有什么用 本篇讲讲工作模式队列,也称之为任务队列 一个生产者发布了多条消息,消费者A可以接受消...

36560
来自专栏北京马哥教育

浅谈小白如何读懂Redis高速缓存与持久化并存及主从高可用集群

一、简介 Redis是一个基于键值(K-V)的高速缓存软件,和他具有相同功能的软件有memcached,但其支持更为复杂的数据结构,例如:List,set,s...

44770
来自专栏谦谦君子修罗刀

程序员面试闪充--版本管理之SVN

在软件开发过程中,通常一个软件项目要靠多人合作完成的。而在此过程中的修修改改一定会存在一些不可避免的问题。可能一不小心就闹出个大乱子呢。 一、源代码管理的问题 ...

27960
来自专栏哲学驱动设计

Rafy 框架 - 时间戳插件

在开发各类数据库应用系统时,业务领域实体往往需要包含“创建时间”、“最后更新时间”、“创建人”、“最后更新人”等跟踪戳属性。这些属性是领域实体的基本属性,几乎所...

9700
来自专栏JAVA烂猪皮

Redis集群

一个简单粗暴的方案是部署多台一模一样的Redis服务,再用负载均衡来分摊压力以及监控服务状态。这种方案的优势在于容错简单,只要有一台存活,整个集群就仍然可用。但...

51520
来自专栏云计算

6个虚拟机备份和恢复的最佳实践

虚拟机的架构与传统的物理机有着天壤之别,因此不适合于传统的备份方案。在本文中,我们将介绍一些虚拟机备份的最佳实践。

229100
来自专栏zhangdd.com

redis的持久化方式RDB和AOF的区别

最近在项目中使用到Redis做缓存,方便多个业务进程之间共享数据。由于Redis的数据都存放在内存中,如果没有配置持久化,redis重启后数据就全丢失了,于是需...

10620
来自专栏容器云生态

redis超时原因系统性排查

1.计算延迟时间: 使用–latency参数  以下参数表示平均超时时间0.03ms。 redis-cli --latency -h 127.0.0.1 ...

2.3K60
来自专栏哲学驱动设计

信息系统开发平台OpenExpressApp - ClickOnce智能部署

    这里讲的是OpenExpressApp的部署方案。主要使用的是ClickOnce作为实施方案来实现:智能部署和智能客户端。不过,这里的使用方式跟以往的不...

24450

扫码关注云+社区

领取腾讯云代金券