一、模板标签

Django模板引擎提供的可以在模板中进行的各种逻辑操作,是函数调用的一种特殊形式,如循环、判断等功能,期语法规则为:

{% tag %} content
{% tag 参数1 参数2 %} content
{% tag %} content {% endtag %}

详细模板标签操作请点击模板标签学习网址

1.常用标签

(1)if...elif...else...       可以使用and/or/in/not/==/!=/<=/>=, 来进行判断

(2)for...in...           与python中的for...in...用法相同

  • forloop.counter       当前迭代次数,下标从1开始
  • forloop.counter0       当前迭代次数,下标从0开始
  • forloop.revcounter     与forloop.counter一样,下标从大到小:3,2,1
  • forloop.revcounter0     与forloop.counter0一样,下标从大到小:2,1,0
  • forloop.first           返回bool类型,如果是第一次迭代,返回True,否则返回False
  • forloop.last         返回bool类型,如果是最后一次迭代,返回True,否则返回False
  • forloop.parentloop     如果发生多层for循环嵌套时,返回上一层的for

(3)for...in...empty...      如果没有数据,跳转到empty中

(4)load                加载第三方标签,例如{% load static %}

(5)url                  返回一个命名了的url的绝对路径

(6)with                变量缓存,相当于导包时的"as", 例如{% with stu1 = student.0.id %}

(7)autoescape         开启和关闭自动转义

2. 使用案例

把学生信息表传到模板,要求:

  1.把女学生的字体改成红色

  2.为每位学生的序号添加链接,点击跳转到该学生的详细信息页面

1).在student/views.py中编辑syudent应用的视图函数

from django.http import HttpResponse
from django.shortcuts import render def detail(request, id):
return HttpResponse('ID为%s的学生详情页' %id) def index(request):
students = [
{"id":10117,"name":'Willy', "age":21, "sex":"Male"},
{"id":10121,"name":'Kitty', "age":20, "sex":"Female"},
{"id":10128,"name":'Kate', "age":19, "sex":"Female"},
{"id":10133,"name":'Tom', "age":22, "sex":"Male"},
{"id":10135,"name":'Rose', "age":20, "sex":"Female"}
]
return render(request, 'student/index.html', context={
'students':students
})

2).在templates/student/index.html中编辑模板

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>模板标签使用案例</title>
</head>
<body>
<div>
<table class="table">
<thead>
<tr>
<th>序号</th>
<th>姓名</th>
<th>年龄</th>
<th>性别</th>
</tr>
</thead>
<tbody>
{% for stu in students %}
{# 使用if标签把女学生的字体颜色变成红色#}
<tr {% if stu.sex == 'femal' %} style={"color":"red"} {% endif %}> {# 添加a标签,点击后跳转到127.0.0.1:8000/student/detail/stu.id页面#}
{# <td><a href="/student/detail/{{ stu.id }}">{{ forloop.counter }}</a></td>#}
<td><a href="{% url 'student:detail' stu.id%}">{{ forloop.counter }}</a></td>
<td>{{ stu.name }}</td>
<td>{{ stu.age }}</td>
<td>{{ stu.sex }}</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
</body>
</html>

二.模板继承与引用

在实际的开发过程中,页面会非常复杂,有多个html文件编辑不同的页面。有时候不同的html文件会有相同的内容,这会造成冗余。针对这种问题,Django的模板引擎提供继承和引用的功能。

1.模板的继承

Django模版引擎通过模版继承,可以让你创建一个base模板,它包含其他站点中的全部元素以及公共部分,并且可以定义能够被子模版覆盖的 blocks 。

子模板通过"extends"标签实现对base模板的继承,并通过"blocks"标签覆盖内容

1).templates/student/base.html:基模板,用于模板的继承页

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>{% block title %}base模板{% endblock %}</title>
{% block link %} {% endblock %}
</head>
<body>
{% block content %}
<h1>我是base模板</h1>
{% endblock %}
</body>
</html>

2).templates/student/inherit.html:继承模板,用于继承base模板

{% extends 'student/base.html' %}
{% block title %}学生信息表{% endblock %}
{% block link %}
<link rel="stylesheet" href="student/css/mystyle.css">
{% endblock %}
<body>
{% block content %}
<h1>我是继承模板,继承base模板</h1>
{% endblock %}
</body>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
</html>
2.模板的引用

Django通过"inclue"标签实现一个模板在特定位置引用另一个模板的内容

1).templates/student/ad.html:广告模板,用于模板的引用页

<body>
<h1 id="h1">我是一个广告, 慎点!</h1>
<script>
var h = document.getElementById("h1");
var color = 'blue';
{#color_change()实现每隔1秒,红蓝之间切换颜色#}
function color_change() {
if (color == 'blue'){
color = 'red';
}
else{
color = 'blue';
}
h.style.color = color;
setTimeout('color_change()', 500)
}
color_change()
</script>
</body>

2).templates/student/iquote.html:引用模板,用于引用ad广告模板

<body>
<div>
<h1> 我是引用模板,引用ad模板</h1>
</div>
<div style="position:fixed; bottom:0px">
{% inclue 'student/ad.html' %}
</div>
</body>

Django入门--模板标签、继承与引用的更多相关文章

  1. Django项目中模板标签及模板的继承与引用【网站中快速布置广告】

    Django项目中模板标签及模板的继承与引用 常见模板标签 {% static %} {% for x in range(x) %}{% endfor %} 循环的序号{% forloop %} 循环 ...

  2. Django 04 模板标签(if、for、url、with、autoeacape、模板继承于引用、静态文件加载)

    Django 04 模板标签(if.for.url.with.autoeacape.模板继承于引用.静态文件加载) 一.if.for.url.with.autoescape urlpatterns = ...

  3. Django——4 模板标签 模板的继承与引用

    Django 模板标签 常用标签 模板的继承与引用 模板标签 标签在渲染的过程中提供任意的逻辑 标签语法: 由%}和 {% 来定义的,例如:{%tag%} {%endtag%} 这个定义是刻意模糊的. ...

  4. django自定义模板标签

    # 创建自定义模板标签目录 django_project_name app_name templatetags (创建Python Packge,注意一定要用templatetags这个名字) my_ ...

  5. Django 自定义模板标签TemplateTags

    创建自定义的模板标签(template tags) Django提供了以下帮助函数(functions)来允许你以一种简单的方式创建自己的模板标签(template tags): simple_tag ...

  6. Django 自定义模板标签和过滤器

    1.创建一个模板库 使用模板过滤器的时候,直接把过滤器写在app里,例如:在app里新建一个templatetags的文件夹,这个目录应当和 models.py . views.py 等处于同一层次. ...

  7. Django 自定义模板标签 报错django.template.exceptions.TemplateSyntaxError: '####' is not a registered tag library. Must be one of:

    我写代码遇到这个错误,但是发现程序没有写错,好像是程序有缓存,重新运行几次就好了. 自定义模板标签,可以不用写views,url直接通过自定义函数把变量传给模板. 具体实现: 1.在app下新建Pyt ...

  8. Django自定义模板标签和过滤器

    1.创建模板库 在某个APP所在目录下新建包templatetags,然后在其中创建存储标签或者过滤器的的模块,名称随意,例如myfilters.py. 在这个模块中编写相关代码. 注意:templa ...

  9. Django之模板层-继承

    模板语法:继承 Django模版引擎中最强大也是最复杂的部分就是模版继承了.模版继承可以让您创建一个基本的"骨架"模版,它包含您站点中的全部元素,并且可以定义能够被子模版覆盖的 b ...

随机推荐

  1. HDU 4531

    很容易判断是BFS,可是,呵呵呵呵呵呵......... HASH判重吧,判连通可以用并查集. 以下代码是转别人的,我码了一下午,发觉越码越丑,呵呵了. http://www.cnblogs.com/ ...

  2. cocos2dx3.0 结构图

    图片较大.请下载看 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdzE4NzY3MTA0MTgz/font/5a6L5L2T/fontsize/400/f ...

  3. JVM —— Java 对象占用空间大小计算

    零. 为什么要知道 Java 对象占用空间大小 缓存的实现: 在设计 JVM 内缓存时(不是借助 Memcached. Redis 等), 须要知道缓存的对象是否会超过 JVM 最大堆限制, 假设会超 ...

  4. C++数组类模板

    * 作为数组类模板,肯定没有vector做得好,可是普通的数组有1个优点就是能直接操作内存.vector在这方面就不是非常方便了. 网上尽管也有数组类模板.多维的设计基本上都不是非常好.我这个类模板多 ...

  5. contest hunter 6803 导弹防御塔

    没什么好写的.写写这题吧 拆点,把一个防御塔拆成m个,表示第i次攻击.瞎yy就好啊 #include<cstdio> #include<iostream> #include&l ...

  6. Wannafly挑战赛25 A 因子 数学

    题面 题意:令 X = n!,给定一大于1的正整数p,求一个k使得 p ^k | X 并且 p ^(k + 1) 不是X的因子,n,,p(1e18>=n>=1e4>=p>=2) ...

  7. Nginx 配置埋点js日志采集

    页面埋点&nginx日志采集 页面(web容器:httpd/nginx负载均衡 + apache server)<===> 日志采集服务器(nginx服务器) 通过某个页面跳转到我 ...

  8. html页面中苹果手机遇到数字换行、样式变形

    在做项目中遇到过几回苹果手机读取html页面时,如果出现一串数字,html页面会折行.变形,最后发现是因为苹果手机的打电话功能,如果html上有数字的话,苹果手机会以为是电话号码,就会改变其样式只需要 ...

  9. java的重载总结

    1.不能以返回值的不同来重载方法,编译都不通过(只有参数类型或者参数个数不同才可以重载方法) 在Java语言中,要重载一个方法,除了要与原方法具有相同的简单名称外,还要求必须拥有一个与原方法不同的(不 ...

  10. 初学 Ajax(涉及 php)

    一直知道 ajax 但是尚未真正了解, 这次看了慕课网的<Ajax全接触>,算是有所收获,入了个门. 需要用到php,因为 Ajax也是向服务器请求(不知道这么解释对不对), 所以还需要配 ...