Django的模板标签相关知识累

01-for标签

在Django模板中,for标签是一个用于循环迭代的重要标签。它的语法类似于Python中的for循环,但在Django模板中有一些特殊的用法。下面是关于Django模板标签for的详细介绍:

基本语法

html 复制代码
{% for item in items %}
    {# 循环体 #}
    {{ item }}
{% endfor %}
  • {% for item in items %}: 开始循环,其中item是循环变量,items是要循环迭代的数据。
  • {# 循环体 #}: 在循环体内部执行的模板代码。
  • {``{ item }}: 显示循环变量的值。
  • {% endfor %}: 结束循环。
    注意:items是一个可迭代对象,并且这个可迭代对像是要在视图函数就已经生成好,你不能在模板中再来生成。即下面的写法是对的:
html 复制代码
    {% for line_number in context1.page_range_pc %}
    <p>第{{ line_number }}行</p>
    {% endfor %}

但是写法:

html 复制代码
	{% for line_number in range(context1.page_range) %}
	    <p>第{{ line_number + 1 }}行</p>
	{% endfor %}

是错的,即for模板标签中是不能使用range()函数的。

循环变量与空变量

在Django模板中,for循环会创建一个循环变量,你可以在循环体内使用这个变量。如果循环的数据为空,你可以使用empty关键字来处理。

html 复制代码
{% for item in items %}
    {{ item }}
{% empty %}
    <p>No items available.</p>
{% endfor %}

循环标签中的过滤器

你可以在for循环中使用过滤器对数据进行处理:

html 复制代码
{% for item in items|filter:"search_query" %}
    {{ item }}
{% endfor %}

循环中的计数器

如果你需要获取当前循环的索引或计数,你可以使用forloop对象:

html 复制代码
{% for item in items %}
    {{ forloop.counter }}: {{ item }}
{% endfor %}
  • forloop.counter: 当前循环的计数器,从1开始。
  • forloop.counter0: 当前循环的计数器,从0开始。

循环中的其他属性

forloop对象还有其他一些属性,如 forloop.first 表示当前是否是循环中的第一个元素,forloop.last 表示当前是否是循环中的最后一个元素。

html 复制代码
{% for item in items %}
    {% if forloop.first %}
        First: {{ item }}
    {% elif forloop.last %}
        Last: {{ item }}
    {% else %}
        {{ item }}
    {% endif %}
{% endfor %}

循环嵌套

Django模板支持循环嵌套,你可以在一个for循环内嵌套另一个。

html 复制代码
{% for category in categories %}
    <h2>{{ category.name }}</h2>
    <ul>
        {% for item in category.items %}
            <li>{{ item.name }}</li>
        {% endfor %}
    </ul>
{% endfor %}

这是一些关于Django模板中for标签的基本用法,你可以根据具体需求结合其他模板标签和过滤器来实现更复杂的逻辑。

相关推荐
用户860821135653 分钟前
SPI机制代码分析
后端
KNeeg_30 分钟前
黑马点评完整代码(RabbitMQ优化)+简历编写+面试重点 ⭐
java·redis·后端·spring·面试·职场和发展·黑马点评
水木流年追梦31 分钟前
【python因果库实战27】逆概率加权模型2
开发语言·python
牛奶1 小时前
开发者的"奇技淫巧":那些让你效率翻倍的实战技巧
前端·后端·程序员
泉城老铁1 小时前
springboot实现word转换pdf
vue.js·后端
铁皮哥1 小时前
【后端/Agent 开发】给你的项目配置一套 .claude/ 工作流:别再裸用 Claude Code 了!
java·windows·python·spring·github·maven·生活
铁皮饭盒1 小时前
今天你会学到这些关键词
前端·后端
oil欧哟1 小时前
🤔 很长时间没写文章了,分享一下最近的一些思考
前端·后端
Walter先生1 小时前
MCP行情数据接入配置踩坑全记录:从Claude Code到Zed八大客户端适配实战
后端·websocket·架构·实时行情数据源
m0_631529821 小时前
CSS如何利用CSS变量进行渐变色管理_提升渐变配置的灵活性
jvm·数据库·python