【Django】视图函数

【Django】视图函数

视图函数的本质是Python中的函数,视图函数负责处理用户的请求并返回响应,该响应可以是网页的HTML内容、重定向、404错误、XML文档、图像或者任何东西,一般在应用中的views.py编写,示例代码如下:

python 复制代码
from django.http import HttpResponse
python
def simpleView(request):
    return HttpResponse('Hello World!')

这里我们创建了名为simpleView的视图函数,该函数通过HttpResponse返回字符串。

注意:每个视图函数需要有个参数,该参数名通常是request。

编写视图函数后,可以在Django文件夹中的urls.py文件使用,也就是在URL路由文件使用,示例代码如下:

python 复制代码
from django.contrib import admin
from django.urls import path
from Product.views import *

urlpatterns = [
    path('admin/', admin.site.urls),
    path('Simple/',simpleView)   # 路由Simple调用视图函数simpleView
]

在终端执行如下代码启动Django项目,

python 复制代码
python manage.py runserver

点击http://127.0.0.1:8000/,如下图所示:

因为在urls.py文件中的urlpatterns有两个url路径,所以Django不知道返回哪个url的响应,导致了报错,这时我们只要访问http://127.0.0.1:8000/Simple/即可返回simpleView视图函数的响应。

当我们想要返回HTML模板文件,需要使用render对象返回响应,示例代码如下:

python 复制代码
def SimpleRender(request):
    return render(request,'Hello World.html')

这里我们在Product文件夹创建了template文件夹并在该文件夹创建名为Hello World.html,该html文件内容如下:

python 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <h1>Hello World!</h1>
</body>
</html>

接下来在urls.py文件中的urlpatterns添加如下代码:

python 复制代码
path('SimpleRender/',SimpleRender)

接下来访问http://127.0.0.1:8000/SimpleRender/即可访问到Hello World.html文件。

除了同步的视图函数,我们还可以使用异步视图函数,示例代码如下:

python 复制代码
async def SimpleRender(request):
    return render(request,'Hello World.html')

没错,在同步视图函数前加async即可变为异步视图函数,其他东西没区别。

相关推荐
未若君雅裁1 分钟前
sa-token前后端分离集成redis与jwt基础案例
后端
江小北2 分钟前
美团面试:MySQL为什么能够在大数据量、高并发的业务中稳定运行?
后端
zhaomy20255 分钟前
从ThreadLocal到ScopedValue:Java上下文管理的架构演进与实战指南
java·后端
华仔啊12 分钟前
10分钟搞定!SpringBoot+Vue3 整合 SSE 实现实时消息推送
java·vue.js·后端
NineData17 分钟前
保姆级!Oracle→达梦零停机迁移攻略,5 步操作,业务零影响!
数据库·程序员
Pocker_Spades_A19 分钟前
在家写的代码,办公室接着改?Jupyter通过cpolar实现远程访问这么玩
ide·python·jupyter
稚辉君.MCA_P8_Java40 分钟前
Gemini永久会员 Go 实现动态规划
数据结构·后端·算法·golang·动态规划
q***31831 小时前
MySQL---存储过程详解
数据库·mysql
q***42821 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
m5655bj1 小时前
使用 Python 高效复制 Excel 行、列、单元格
开发语言·python·excel