python--Django模板系统

1.模板系统(template)
向页面中填充内容。
(1).模板系统常用符号{{}}和{%%}

如果在模板中需要解析变量使用{{}}.
如果在模板中进行逻辑相关操作使用{%%}
注释 {# … #},单行注释。

(2).变量

在Django的模板系统中变量使用的语法:{{ 变量名 }}。
当模版引擎遇到变量,就会用值替换掉变量。
变量的命名可以是字母数字以及下划线 ("_")的组合。
变量名称中不能有空格或标点符号。
练习1:将index页面中的{{name}}替换为张三。
demo01.html文件

在这里插入图片描述
注意:key的名称和模板中的变量名称相同。
urls.py文件
在这里插入图片描述
(3).点(.)的特殊含义

点(.)在模板语言中有特殊的含义。当模版系统遇到点("."),它将以以下顺序查询:
字典查询 :如果向页面传递的是一个字典类型变量,变量名.key 获取值
属性或方法查询:如果传递一个对象,变量名.变量名
(此变量名有可能是属性,有可能是无参数方法名称)。
数字索引查询:如果传递一个列表,变量名.索引。

Views.py
在这里插入图片描述
Index02.html页面
在这里插入图片描述
Urls.py文件
在这里插入图片描述

注意:
如果使用的变量不存在, 它被默认设置为(空字符串) 。

2.Filters(过滤器)
在Django的模板语言中,通过使用 过滤器 来改变变量的显示。(注:过滤器是函数)
过滤器的语法: {{ 变量名|过滤器名称:参数 }}
使用管道符"|"来应用过滤器。
例如:{{ name|lower }}会将name变量应用lower过滤器之后再显示它的值。lower在这里的作用是将文本全都变成小写。
(1).default
如果一个变量是false或者为空,使用给定的默认值。 否则,使用变量的值。
{{ value|default:“nothing”}}
如果value没有传值或者值为空的话就显示nothing
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(2).length
返回值的长度,作用于字符串和列表。
{{ value|length }}
返回value的长度,如 value=[‘a’, ‘b’, ‘c’, ‘d’]的话,就显示4.
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(3).slice
切片
格式:{{value|slice:“2:-1”}}
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(4).date
日期格式化过滤器
格式:{{ value|date:“Y-m-d H:i:s”}}
可用的参数:

格式化字符描述示例输出
a'a.m.'或'p.m.'(请注意,这与PHP的输出略有不同,因为这包括符合Associated Press风格的期间)'a.m.'
A'AM'或'PM'。'AM'
b月,文字,3个字母,小写。'jan'
B未实现。
cISO 8601格式。 (注意:与其他格式化程序不同,例如“Z”,“O”或“r”,如果值为naive datetime,则“c”格式化程序不会添加时区偏移量(请参阅datetime.tzinfo) 。2008-01-02T10:30:00.000123+02:00或2008-01-02T10:30:00.000123如果datetime是天真的
d月的日子,带前导零的2位数字。'01'到'31'
D一周中的文字,3个字母。''、'GMT'、'-500'、'US/Eastern'等
e时区名称 可能是任何格式,或者可能返回一个空字符串,具体取决于datetime。''、'GMT'、'-500'、'US/Eastern'等
E月份,特定地区的替代表示通常用于长日期表示。'listopada'(对于波兰语区域,而不是'Listopad')
f时间,在12小时的小时和分钟内,如果它们为零,则分钟停留。 专有扩展。'1','1:30'
F月,文,长。'一月'
g小时,12小时格式,无前导零。'1'到'12'
G小时,24小时格式,无前导零。'0'到'23'
h小时,12小时格式。'01'到'12'
H小时,24小时格式。'00'到'23'
i分钟。'00'到'59'
I夏令时间,无论是否生效。'1'或'0'
j没有前导零的月份的日子。'1'到'31'
l星期几,文字长。'星期五'
L布尔值是否是一个闰年。True或False
m月,2位数字带前导零。'01'到'12'
M月,文字,3个字母。“扬”
n月无前导零。'1'到'12'
N美联社风格的月份缩写。 专有扩展。'Jan.','Feb.','March','May'
oISO-8601周编号,对应于使用闰年的ISO-8601周数(W)。 对于更常见的年份格式,请参见Y。'1999年'
O与格林威治时间的差异在几小时内。'+0200'
P时间为12小时,分钟和'a.m。'/'p.m。',如果为零,分钟停留,特殊情况下的字符串“午夜”和“中午”。 专有扩展。'1 am','1:30 pm' / t3>,'midnight','noon','12:30 pm' / T10>
rRFC 5322格式化日期。'Thu, 21 Dec 2000 16:01:07 +0200'
s秒,带前导零的2位数字。'00'到'59'
S一个月的英文序数后缀,2个字符。'st','nd','rd'或'th'
t给定月份的天数。28 to 31
T本机的时区。'EST','MDT'
u微秒。000000 to 999999
U自Unix Epoch以来的二分之一(1970年1月1日00:00:00 UTC)。
w星期几,数字无前导零。'0'(星期日)至'6'(星期六)
WISO-8601周数,周数从星期一开始。1,53
y年份,2位数字。'99'
Y年,4位数。'1999年'
z一年中的日子0到365
Z时区偏移量,单位为秒。UTC以西时区的偏移量总是为负数,对于UTC以东时,它们总是为正。-43200到43200

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(5).safe
Django的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,比如我们做一个内容管理系统,后台添加的文章中是经过修饰的,这些修饰可能是通过一个类似于FCKeditor编辑加注了HTML修饰符的文本,如果自动转义的话显示的就是保护HTML标签的源文件。为了在Django中关闭HTML的自动转义有两种方式,如果是一个单独的变量我们可以通过过滤器“|safe”的方式告诉Django这段代码是安全的不必转义。
比如:value = “点我
格式:{{ value|safe}}
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
(6).cut
移除value中所有的与给出的变量相同的字符串
格式:{{ value|cut:’ ’ }},如果value为’i love you’,那么将输出’iloveyou’.
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(7).join
使用拼接符连接列表,例如Python的str.join(list)
格式: {{value|join:”_”}}
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

注意:
1.’|'左右没有空格
2.django的模板语言中提供了大约六十个内置过滤器。

3.tags 标签
使用Django中的标签可以在模板中做一些简单的逻辑判断。
标签和{%%}配合使用。
(1).for标签
格式:{%for 临时遍历 in 序列%} … {%endfor%}
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
for循环可用的一些参数:
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

(2).for…empty标签

如果变量名不存在或者内容为空的时候显示{%empty%}中的内容,否则不执行。
格式:
{% for game in games %}

{% empty %}

{% endfor %}
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(3).if 标签
格式:
{% if 判断条件 %}

{% endif %}
注: if 语句支持 and、or、==、<、>、!=、<=,>=,in、not in、is、is not判断。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(4).if … else 标签
格式:
{% if name_length|length > 6 %}

{% else %}

{% endif %}
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(5).if…elif…else 标签
格式:
{% if name_length|length > 6 %}

{% elif age == 20 %}

{% else %}

{% endif %}
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
(6).load 和 static 标签
当我们想在页面上使用一些静态资源例如图片、js、css 。这时候我们就要使用到static标签了。

例如在页面中显示一张本地图片。
操作步骤:
a.新建一个文件夹来盛放静态资源,例如 static,为了和后面的static标签区分,这里使用 statics名称
在这里插入图片描述
b.将statics文件夹加载到python搜索路径中。
在这里插入图片描述
c.在页面上最开始位置使用 {%load static %} load 标签 来加载 static 标签。
在这里插入图片描述
d.在要展示图片的地方 使用 {% static ‘图片路径’}
{% static ‘图片路径’} 表示 使用
在这里插入图片描述
在这里插入图片描述
如果将static 改成 statics
在这里插入图片描述
在这里插入图片描述
注意:如果不想在每一个页面中都使用 {%load static %} ,可在settings.py中进行如下配置
在这里插入图片描述
在这里插入图片描述
4.模板继承
当我们浏览一个网站的时候发现里面的网页大部分都是相同的。
例如:
在这里插入图片描述
1.定义母板
在这里插入图片描述
在这里插入图片描述
2.继承母板
语法:{% extends ‘base.html’ %}
在这里插入图片描述
在这里插入图片描述
3.组件
可以将常用的页面内容如导航条,页尾信息等不变的组件可以保存在单独的文件中,然后在需要使用的地方按如下语法导入即可。
{% include ‘navbar.html’ %}
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个常见的问题,代码实现如下: 1. 创建一个 Django 应用程序 在 Django 中,应用程序是指一个包含一组相关模型和视图的 Python 包。要创建一个新的 Django 应用程序,需要使用以下命令: ``` python manage.py startapp myapp ``` 这将在当前目录下创建一个名为 myapp 的新应用程序。 2. 创建用户认证模型 要创建一个用户认证模型,可以使用 Django 提供的内置 User 模型。在 myapp/models.py 文件中添加以下代码: ``` from django.contrib.auth.models import User class UserProfile(models.Model): user = models.OneToOneField(User, on_delete=models.CASCADE) # Add more fields here as needed ``` 此模型将扩展内置 User 模型,并添加新字段。 3. 创建登录表单 要创建一个登录表单,可以使用 Django 提供的内置 AuthenticationForm 表单类。 在 myapp/forms.py 文件中添加以下代码: ``` from django import forms from django.contrib.auth.forms import AuthenticationForm class LoginForm(AuthenticationForm): username = forms.CharField(label="用户名", max_length=30, widget=forms.TextInput(attrs={'placeholder': '用户名'})) password = forms.CharField(label="密码", max_length=30, widget=forms.PasswordInput(attrs={'placeholder': '密码'})) ``` 此 LoginForm 类继承了内置 AuthenticationForm 类,并添加了两个输入框字段。 4. 创建登录视图 要创建一个登录视图,可以使用 Django 提供的内置 LoginView 视图类。在 myapp/views.py 文件中添加以下代码: ``` from django.contrib.auth.views import LoginView class CustomLoginView(LoginView): authentication_form = LoginForm template_name = 'login.html' # login template file name ``` 此 CustomLoginView 类扩展了内置 LoginView 类,用在 LoginForm 类来处理用户输入,template_name 可以根据自己的需要进行更改。 5. 创建登录页面 在 Django 中,你需要创建一个 HTML 模板,用于呈现登录页面。在 myapp/templates 目录下创建一个名为 login.html 的文件,其内容如下: ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>登录</title> </head> <body> <form method="post"> {% csrf_token %} {{ form.as_p }} <button type="submit">登录</button> </form> </body> </html> ``` 此 HTML 模板将 LoginView 类所提供的表单渲染出来,表单元素都包含在 form.as_p 中,包括 csrf_token, 按钮使用了 HTML5 中的会提交 type="submit" 属性进行登录。 6. 在 urls.py 文件中添加视图路由 最后,你需要定义如何访问你的登录页面,可以在 myapp/urls.py 文件中添加以下代码: ``` from django.urls import path from myapp.views import CustomLoginView urlpatterns = [ path('login/', CustomLoginView.as_view(), name='login'), ] ``` 这将使你的登录页面可用于 myapp 登录。 这是 Django 中实现登录的一种基本方法,具体实现可能会根据需求而有所不同。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值