Django学习之预备知识

七、Django学习之预备知识


其他关于Python Web开发笔记:(如果遇到问题可以一起交流~)

一、Flask学习之HTML-CSDN博客

二、Flask学习之CSS-CSDN博客

【接上篇】二、Flask学习之CSS(下篇)-CSDN博客

三、Flask学习之BootSrap-CSDN博客

四、Flask学习之JavaScript-CSDN博客

五、Flask学习之MySQL-CSDN博客

六、Django学习之小试牛刀-CSDN博客

1.模板语言

1.1. 准备工作

首先在urls.py添加学习模板语言的url:

python 复制代码
path("tpl/", views.tpl)

然后在views.py里面添加对应的视图函数:

python 复制代码
from django.shortcuts import render

def tpl(request):
    return render(request, "tpl.html")

最后在templates文件夹下创建对用的HTML文件tpl.html。

1.2. 显示变量

变量的形式如下:{``{ variable }}。当模板引擎遇到一个变量时,它会评估该变量并将其替换为结果。变量名称由字母数字字符和下划线("_")的任意组合组成,但不能以下划线开头,也不能是数字。

例如将tpl函数改为:

python 复制代码
def tpl(request):
    name = "panda"
    return render(request, "tpl.html", {"name": name})

然后将HTML文件改为:

HTML 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>模板语言学习</h1>
{{ name }}
</body>
</html>

运行结果:

由此也可以想到能够展示列表:

python 复制代码
def tpl(request):
    name = "panda"
    my_list = ["apple", "banana", "cherry"]
    return render(request, "tpl.html", {"name": name, "my_list": my_list})

然后在HTML中加入:

html 复制代码
{{ my_list }}

结果:

如果要提取列表中每一个变量不能使用Python中的[],要使用.

html 复制代码
{{ my_list.1 }}

1.3. for循环

html 复制代码
{% for each in my_list %}
    <div>
        {{ each }}
    </div>
{% endfor %}

效果:

1.4. 条件语句

if语句:

html 复制代码
{% if name == "panda" %}
    <div>{{ name }}</div>
{% endif %} 

if-else语句:

html 复制代码
{% if name == "name" %}
    <div>
    {{ name }}
    </div>
{% else %}
    <div>
    Hello World!
    </div>
{% endif %}

if-elif-else语句:

html 复制代码
{% if name == "name" %}
    <div>
        {{ name }}
    </div>
{% elif name == "666" %}
    <div>
        666
    </div>
{% else %}
    <div>
        Hello World!
    </div>
{% endif %}

2.请求和响应

请求:

python 复制代码
# 1.获取请求的方式
print(request.method)
# 2.获取GET方式传回的值
print(request.GET)
# 3.获取POST方式传回的值
print(request.POST)

响应:

python 复制代码
# 1.直接返还字符串
# return HttpResponse("Hello, world!")

# 2.返还一个HTML文件,同时可以传参数
# return HttpResponse("something.html",{"something":"something"})

# 3.重定向
return redirect("www.google.com")

3.案例

3.1. 源代码

在urls.py中添加:

python 复制代码
path("login/", views.login)

在views.py中添加:

python 复制代码
def login(request):
    if request.method == "GET":
        return render(request, "login.html")
    username = request.POST.get("username")
    passwd = request.POST.get("passwd")
    if username == "panda" and passwd == "123456":
        return HttpResponse("登录成功")
    return render(request, "login.html", {"error_msg": "用户名或密码错误,请重试"})

在templates中添加login.html:

HTML 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>用户登录</h1>
<form method="post" action="/login/">
    {# Django的安全机制,不加没办法正常打开界面 #}
    {% csrf_token %}
    用户名:<input type="text" name="username" placeholder="请输入用户名......">
    密 码:<input type="password" name="passwd" placeholder="请输入密码......">
    <input type="submit" value="提 交">
    <span style="color: red">{{ error_msg }}</span>
</form>
</body>
</html>

3.2. 详细说明

在浏览器搜索框中输入对应的网址属于GET请求方式,所以在访问login页面的时候会直接跳转到login.html文件,然后显示它的内容,但是HTML文件中有一句是<span style="color: red">{``{ error_msg }}</span>,需要python文件进行传值error_msg,但是如果没有传值的话,Django默认是空,所以这一句话在这时候不起作用。

当用户输入密码并提交的时候,由于login.html文件设置的表单提交是POST提交方式,所以会触发这个代码段:

python 复制代码
username = request.POST.get("username")
passwd = request.POST.get("passwd")
if username == "panda" and passwd == "123456":
    return HttpResponse("登录成功")
return render(request, "login.html", {"error_msg": "用户名或密码错误,请重试"})

如果用户输入的用户名和密码均正确,就直接执行return HttpResponse("登录成功")

但是如果输入的用户名和密码有一个不正确就会触发这句话return render(request, "login.html", {"error_msg": "用户名或密码错误,请重试"})这时候,login.html文件中的error_msg有值了,就会显示对应的样式:

相关推荐
小赖同学啊2 小时前
物联网数据安全区块链服务
开发语言·python·区块链
码荼2 小时前
学习开发之hashmap
java·python·学习·哈希算法·个人开发·小白学开发·不花钱不花时间crud
武昌库里写JAVA3 小时前
Oracle如何使用序列 Oracle序列使用教程
java·开发语言·spring boot·学习·课程设计
小陈phd3 小时前
李宏毅机器学习笔记——梯度下降法
人工智能·python·机器学习
kk爱闹3 小时前
【挑战14天学完python和pytorch】- day01
android·pytorch·python
Blossom.1184 小时前
机器学习在智能建筑中的应用:能源管理与环境优化
人工智能·python·深度学习·神经网络·机器学习·机器人·sklearn
祁思妙想4 小时前
八股学习(三)---MySQL
数据库·学习·mysql
亚力山大抵4 小时前
实验六-使用PyMySQL数据存储的Flask登录系统-实验七-集成Flask-SocketIO的实时通信系统
后端·python·flask
showyoui4 小时前
Python 闭包(Closure)实战总结
开发语言·python
amazinging5 小时前
北京-4年功能测试2年空窗-报培训班学测开-第四十一天
python·学习·appium