django(3)jinja2模版的使用

启动模版

安装jinja2

pip install jinja2

配置setting

TEMPLATES中添加配置

python 复制代码
    {
        'BACKEND': 'django.template.backends.jinja2.Jinja2',
        'DIRS': [os.path.join(BASE_DIR,'jinja2')],  #模版在项目中的所在位置
    }

template中各项的含义

这个配置项中模版自上而下加载,重名优先使用上面的

python 复制代码
TEMPLATES = [
    {
        # 配置哪一种模版
        'BACKEND': 'django.template.backends.django.DjangoTemplates',   # django默认的自带模版
        # 存放模版的目录位置
        # 'DIRS': [BASE_DIR / 'templates']
        'DIRS': [os.path.join(BASE_DIR,'templates')]    # 用os拼接,找到模版所在位置
        ,
        # 模版应用范围,True为全局(整个工程下)
        'APP_DIRS': True,
        # 其它相关配置
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
    {
        'BACKEND': 'django.template.backends.jinja2.Jinja2',
        'DIRS': [os.path.join(BASE_DIR,'jinja2')],  #模版在项目中的所在位置
    }
]

新建jinja2的模版目录

根据新配置的 'DIRS': [os.path.join(BASE_DIR,'jinja2')],新建jinja2文件夹

这样使用在视图中使用render的时候就可以直接找到jinja2目录下的文件了

python 复制代码
def go_jinja2(request):
    return render(request,"jinja2_home.html")

编辑模版

变量

模版中的变量用{{}}包裹{{变量名}},插值表达式

传入模版的参数可以是字符,数字,对象,列表

html 复制代码
<body>
<h1>h1标签</h1>
<p>用户名:{{ username }}</p>
<p>年龄:{{ age }}</p>
<p><img src="{{ img_url }}" alt=""></p>
<p>用户列表</p>
</body>

模版标签

用{%%}包裹循环或判断

html 复制代码
<body>
<h1>h1标签</h1>
<p>用户名:{{ username }}</p>
<p>年龄:{{ age }}</p>
<p><img src="{{ img_url }}" alt=""></p>
<p>用户列表</p>
{% for user in list_users %}
<p>{{ user.username }}&emsp;{{ user.age }}</p>
{% endfor %}
</body>

循环:

html 复制代码
循环 
{% for user in list_users %}        {% endfor %}
字典循环
{% for key,values in data.items %}         {% endfor %}
重复循环(循环嵌套)
{% cycle "row1" "row2" %}
循环中的变量

|------------------|-----------------|
| forloop.first | 如果是第一次迭代,为True |
| forloop.last | 如果是最后一次迭代,为True |
| forloop.counter0 | 计数器,从0开始 |
| forloop.counter | 计数器,从1开始 |

eg:

python 复制代码
def tag(request):
    list_user = [
        {"name": "ikun1",
         "age": 2.5
         },
        {"name": "ikun2",
         "age": 2.5,
         "sex":"沃尔玛购物袋"
         }
    ]
    return render(request,"tag.html",{
        "list_user":list_user
    })
html 复制代码
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .row1{
            color: red;
        }
        .row2{
            color: green;
        }
    </style>
</head>
<body>
<h1>用户列表</h1>
{% for i in list_user %}
    <p class="{% cycle 'row1' 'row2' %}">第{{ forloop.counter }}个用户</p>
    {% for key,value in i.items %}
        <p>{{ key }} = {{ value }}</p>
    {% endfor %}
{% empty %}
    <p>无</p>
{% endfor %}
</body>

判断

html 复制代码
{% if 条件 %}        {% endif %}
html 复制代码
<body>  
    {% if user.role == 'admin' %}  
        <p>Hello, Admin!</p>  
    {% elif user.role == 'editor' %}  
        <p>Hello, Editor!</p>  
    {% else %}  
        <p>Hello, Regular User!</p>  
    {% endif %}  
</body> 

url标签

可以获取静态文件,解析静态文件

setting中设置好资源目录和链接

html 复制代码
STATIC_URL = "/static/"
STATIC_ROOT = [os.path.join(BASE_DIR,"static")]
# STATICFILES_DIRS = [os.path.join(BASE_DIR,"static")]
html 复制代码
<img src="{% static 'images/ikun.jpg' %}" alt="">

时间

见官网

内置模板标签和过滤器 | Django 文档 | Django

eg:

html 复制代码
{% now 'j S F Y H:i:s' %}

注释

html 复制代码
{# html注释在源代码中能看到内容,标签注释在编译时就将注释内容去掉了 #}

过滤器

首先在模块下新建一个叫templatetags的包

在包下新建过滤器文件

python 复制代码
from django import template

register = template.Library()
# 注册过滤器
@register.filter(name='fmt_uname')# 用户名格式化
def fmt_uname(value):
    return "{}***".format(value[0])

这样过滤器就创建好了

测试

python 复制代码
def mine_filter(request):
    username = "三"
    return render(request, "mine_filter.html", {
        "username": username
    })
python 复制代码
<p>{{ username | fmt_uname }}</p>
相关推荐
好看资源平台18 分钟前
网络爬虫——综合实战项目:多平台房源信息采集与分析系统
爬虫·python
凡人的AI工具箱21 分钟前
15分钟学 Go 第 60 天 :综合项目展示 - 构建微服务电商平台(完整示例25000字)
开发语言·后端·微服务·架构·golang
陈王卜24 分钟前
django+boostrap实现发布博客权限控制
java·前端·django
java亮小白199729 分钟前
Spring循环依赖如何解决的?
java·后端·spring
进击的六角龙39 分钟前
深入浅出:使用Python调用API实现智能天气预报
开发语言·python
檀越剑指大厂39 分钟前
【Python系列】浅析 Python 中的字典更新与应用场景
开发语言·python
2301_811274311 小时前
大数据基于Spring Boot的化妆品推荐系统的设计与实现
大数据·spring boot·后端
湫ccc1 小时前
Python简介以及解释器安装(保姆级教学)
开发语言·python
孤独且没人爱的纸鹤1 小时前
【深度学习】:从人工神经网络的基础原理到循环神经网络的先进技术,跨越智能算法的关键发展阶段及其未来趋势,探索技术进步与应用挑战
人工智能·python·深度学习·机器学习·ai
羊小猪~~1 小时前
tensorflow案例7--数据增强与测试集, 训练集, 验证集的构建
人工智能·python·深度学习·机器学习·cnn·tensorflow·neo4j