模板语法
本质上:在HTML中写一些占位符,由数据对这些占位符进行替换和处理。
-
视图函数中的render内部
- 读取含有模板语法的HTML文件
- 内部进行渲染,最终得到只包含HTML标签的字符串
- 最后将渲染完成的字符串返回给用户浏览器
-
数据替换
-
if语法
-
效果展示
请求和响应
请求
- 获取请求方式 GET/POST
print(request.method)
- 在url上传递值
print(request.GET)
- 在请求体中提交数据
print(request.POST)
响应
- 内容字符串返回给请求者
return HttpResponse("返回")
- 读取HTML的内容+渲染 ——> 将字符串内容返回给用户浏览器
return render(request, 'something.html',{"title": "来了"})
- 让浏览器重定向到其他页面
return redirect("https://www.baidu.com")
案例:用户登录
- 对应关系
views.py
import requests
from django.shortcuts import render, HttpResponse, redirect
def login(request):
if request.method == "GET":
return render(request, "login.html")
# 如果是POST请求,获取用户提交的数据
# print(request.POST)
username = request.POST.get("user")
password = request.POST.get("pwd")
if username == "root" and password == "123":
return HttpResponse("登录成功")
# return HttpResponse("登陆失败")
return render(request, 'login.html',{"error_msg": "用户名或密码错误"})
login.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>用户登录</h1>
<form method="post" action="/login/">
{% csrf_token %}
<input type="text" name="user" placeholder="用户名">
<input type="password" name="pwd" placeholder="密码">
<input type="submit" value="提交">
<span style="color: red">{{ error_msg }}</span>
</form>
</body>
</html>
- CSRF 相当于多了一层验证
- 在form表单中加上一句