Flask入门之Jinjia模板的一些语法
原文:https://www.cnblogs.com/wongbingming/p/6807771.html
Flask入门之Jinjia模板的一些语法
1. 变量表示
{{ argv }}
2. 赋值操作
{% set links = [('home',url_for('.home')),('service',url_for('.service')),('about',url_for('.about')),
] %}
3. if判断
{% if not loop.first %}|{% endif %}
4. for 循环
{% for label,link in links %}{% if not loop.first %}|{% endif %}<a href="{{ link }}">{{ label }}</a>
{% endfor %}
5. 定义测试函数
上面 loop.first 就是一个测试函数,这个我们也可以自定义
定义是在Sample.py 里定义的,current_link是HTML中可使用测试函数名称(可选)
@app.template_test('current_link')
def is_current_link(link):return link == request.path
HTML中,使用例子
<body>
{% set links = [('home',url_for('.home')),('service',url_for('.service')),('about',url_for('.about')),
] %}<nav>{% for label,link in links %}{% if not loop.first %}|{% endif %}<a href="{% if link is current_link %}#{% else %}{{ link }}{% endif %}">{{ label }}</a>{% endfor %}
</nav>
</body>
---------------------------------------------分割线---------------------------------------------
6. 块block
Flask强大的地方就可以引用模板,而且非常方便。
这里不得不介绍block这个概念。
模板的文件一般放在templates文件夹下,我们这里新建一个HTML文件,存放模板,'base.html'
在这里面也,编排了整个页面的排版,里面会用到很多block的占位符。
每个block都代表一段html语句块,而这些块在哪里定义呢,可以在当前的base.html中定义,也可以在别的html中定义。反正要有一处定义,没有定义块只是没有效果而已
定义的时候,home.html 顶部必须说明继承关系(如果py文件链接的是home.html,但home.html引用了base.html的模板,就要说明)
{% extends 'base.html' %}
块的定义格式,endblock 后面块名可以省略,有时候加上会让结构更加明晰
{% block 块名 %}块内容
{% endblock (块名)%}
定义了块之后,base.html中对应的块,就会被这些块内容覆盖。
块的覆盖情况
有一种情况,base.html中定义了block B 块内容1,但是在home.html也定义block B 块内容2,注意这时会优先显示内容2,因为把内容1覆盖了。
理解起来,就是base.html是通用模板,我们可以直接引用过来,没有问题,但是也可以自定义块,修改通用模板的内容,达到我们想要的效果。
还有一种情况,我们既不想不覆盖通用模板的内容,又想在其基础上,增加一些东西,这也是可以的。
举个例子:在base.html中
<footer>{% block footer %}<p>Posted:Bikmin</p><p>Contact with:<a href="someone@example.com">someone@example.com</a> </p>{% endblock %}
</footer>
如果我们不再自定义块,就会使用base.html通用模板的内容,效果如下
觉得这个模板还行,不想覆盖,还想在这个基础上再添加些东西,想要上面添加一条水平线作为分隔符,该怎么做呢
做法是,也是在home.html重新定义块,但是需要用到super()函数
{% block footer %}<hr>{{ super() }}
{% endblock %}
{{ super() }} 就表示了通用模板里的内容
在一个项目HTML中,块被定义多次,是会被覆盖的。
有时候,我们想引用块的内容,又不想写一串很长的块内容,这时候可以用下面的语法,不管在哪个html文件里定义的都可以,只要有继承关系
{{ self.块名() }}
7. 包含页
如果有一些HTML代码是经常用到的固定的,为了避免整个HTML文档看起来很拥挤,内容嘈杂。
可以将这一部分的代码,保存为了一个HTML模板,然后要用的时候,再用
{% include 'includes/_head.html' %}
包含的方法引用过来,引号里是路径,includes是templates下的一个文件夹,这个看你放在哪里,就填哪里的路径了。
8. 宏macro
学了这么多,发现Flask中到处都是模板,仔细想想Python中的函数不也像是模板吗?只要输入参数,就可以实现特定的功能。
所以Jinjia里当然少不了。
- 宏的定义(举个例子)
下面定义一个<input/>的函数,通过做成宏,可以将一些参数修改成我们想要的默认值,然后调用的时候就像函数一样调用,很方便。
{# 定义宏 #}
{% macro input(name,value='',type='text',size=20) %}<input type="{{ type }}"name="{{ name }}"value="{{ value }}"size="{{ size }}"/>
{% endmacro %}
- 宏的调用
{{ input('username') }}
{{ input('password',type='password') }}
- 宏的集合做成库
宏跟函数差不多,Python的函数可以封装在库里,那么是不是也可以将很多宏集合在一起(一个HTML中),要用的时候像调用库函数一样import使用呢?
答案是当然可以的。这个做法还有一个好处,就是让我们的主HTML文件,内容更加简练。节省空间,可读性更强。
下面我们举例将一个macro放在'_macro.html'中
然后如何引入到我们的文件里呢
{% import '_macro.html' as ui %}
这里注意,必须要加 as 库名 ,不然我们引用函数的时候,都不知道从哪里来的函数
调用的方式也有点改变,如下
{{ ui.input('username') }}
{{ ui.input('password',type='password') }}
是不是跟Python的使用函数一模一样?
小项目实战
#Sample.py
# coding:utf-8
from flask import Flask,render_template,request,url_forapp = Flask(__name__)@app.route('/')
def home():return render_template('home.html',title_name = 'welcome')@app.route('/service')
def service():return 'service'@app.route('/about')
def about():return 'about'@app.template_test('current_link')
def is_current_link(link):return link == request.pathif __name__ == '__main__':app.run(debug=True)
#home.html
{% extends 'base.html' %}
{% import '_macro.html' as ui %}{% block title %}{{ title_name }}{% endblock %}{% block content %}
{% set links = [('home',url_for('.home')),('service',url_for('.service')),('about',url_for('.about')),
] %}<nav>{% for label,link in links %}{% if not loop.first %}|{% endif %}<a href="{% if link is current_link %}#{% else %}{{ link }}{% endif %}">{{ label }}</a>{% endfor %}
</nav><p>{{ self.title() }}</p>{{ ui.input('username') }}{{ ui.input('password',type='password') }}
{% endblock content %}{% block footer %}<hr>{{ super() }}
{% endblock %}
#base.html
<!DOCTYPE html>
<html lang="en">
<head>{% block head %}{% include 'includes/_head.html' %}{% endblock %}
</head>
<body><header>{% block header %}{% endblock %}</header><div>{% block content %}<p>hello</p>{% endblock %}</div>{% for item in items %}<li>{% block loop_item scoped %}{{ item }}{% endblock %}</li>{% endfor %}<footer>{% block footer %}<p>Posted:Bikmin</p><p>Contact with:<a href="someone@example.com">someone@example.com</a> </p>{% endblock %}</footer>
</body>
</html>
#_head.html
<meta charset="UTF-8">
<link href="{{ url_for('static',filename='site.css') }}" rel="stylesheet">
<title>{% block title %}{% endblock %}</title>
#macro
{# 定义宏 #}
{% macro input(name,value='',type='text',size=20) %}<input type="{{ type }}"name="{{ name }}"value="{{ value }}"size="{{ size }}"/>
{% endmacro %}
运行项目
---------------------@@完成@@---------------------
Flask入门之Jinjia模板的一些语法相关推荐
- Flask框架Jinjia模板中常用语法
文章目录 1.变量表示 2.判断 3.for循环 4.继承 5.块 6.url链接 7.加载静态文件 1.变量表示 {{ args }} 2.判断 {% if a == 1 %}{% endif %} ...
- Flask入门系列(转载)
一.入门系列: Flask入门系列(一)–Hello World 项目开发中,经常要写一些小系统来辅助,比如监控系统,配置系统等等.用传统的Java写,太笨重了,连PHP都嫌麻烦.一直在寻找一个轻量级 ...
- Flask 的 template模板 与 jinja2语法
Flask 的 template模板 与 jinja2语法 Flask使用的是Jinja2模板,所以其语法和Django基本无差别 1.模板基本数据的渲染 变量 {{..}} 列表 {% for it ...
- 泛型模板和STL语法入门
泛型模板和STL语法入门 STL简介 STL是Standard Template Library的简称,中文名标准模板库,惠普实验室开发的一系列软件的统称.它是由Alexander Stepanov. ...
- Flask入门学习---初步了解模板
1.为什么需要模板引擎(template engine)? 在上面的例子中,我们视图函数向客户端返回一行HTML代码.当有大量HTML代码的时候,我们应该将它们都存储在一个文件里面,从而让控制器和用户 ...
- flask入门2-模板引擎
day2模板 模板引擎 说明:模板文件就是按照一定的规则书写的展示效果的HTML文件 模板引擎就是负责按照指定规则进行替换的工具 模板引擎选择jinja2 一.渲染模板的方法 将渲染的模板进行返回 r ...
- Web框架——Flask系列之Jinja2模板引擎(二)
Jinja2模板引擎简介 一.Jinja2模板概述 用来展示数据的html页面,这个过程也通常称为渲染,属于Jinja2的功能 使用模板的好处: 视图函数只负责业务逻辑和数据处理(业务逻辑方面) 而模 ...
- Flask框架四:模板继承以及豆瓣案例
1.模板继承 ①为什么会有模板继承而不用include调用模板:include是引用模板的标签,将模板的内容直接显示,但是当页面有变化的时候,比如多了一个侧边栏的内容,或者想改输入框为按钮,这时候就要 ...
- velocity模板引擎-vm语法整理
velocity模板引擎-vm语法整理 模板引擎我目前接触过两次, 第一次是在前后端还未分离时,考虑到部分页面数据比较固定,一定时间内不会变动,这样每次从后台加载数据渲染页面明显会消耗性能以及资源浪费 ...
最新文章
- Jupyter notebook与Spyder集成
- 数据结构:栈实现逆波兰计算器
- 计算机与广播电视论文,计算机技术在广播电视节目的应用论文
- LAMP攻略: LAMP环境搭建,Linux下Apache,MySQL,PHP安装与配置
- cat命令详解_需要!Linux常用监视和故障排查命令详解
- 动态规划——滑雪(洛谷 P1434)
- CCF201509-3 模板生成系统(100分)
- Linux交换空间(swap space)
- 会场安排问题(贪心算法) Comparator类排序的学习
- [HNOI2005][BZOJ1202] 狡猾的商人
- SSH和SSM对比(学完后的总结)
- opencv实现眼动检测【胡子哥哥】
- stm32 ST-Link V2下载出现 No target connected问题
- 时间格式中,hh小写的是12小时制,大写(HH)是24小时制的。
- Odoo产品分析 (三) -- 人力资源板块(6) -- 工资表(1)
- Python列表统计重复元素
- java变量定义规则说法正确_下列变量命名规范说法正确的是( )。
- Linux常用命令笔记
- uniapp网上商城排坑专业户
- Vue+vant 直播间 - 在离开直播间时弹出确认框
热门文章
- mongodb安装_MongoDB和Web应用程序
- html5混合编写,Html5混合开发环境的搭建
- linux中iso文件怎么安装系统文件,我有linux的iso文件,要怎么安装系统
- html footer 布局,详解CSS经典布局之Sticky footer布局
- java项目集成mybatis_JAVA应用程序单独集成Mybatis使用Demo
- mybatis plus 使用函数_这些Mybatis-Plus使用技巧,太火了
- 俄罗斯机器人雄鹿_世界上最''倒霉''的机器人:逼真到难以置信,为忍受痛苦而生...
- 神舟战神_14英寸小钢炮 神舟战神S72021S5开箱
- 听说这是准备下班的时候,测试又提bug过来的表情
- 课堂上的社死现场...