Flask模板继承深入理解与应用

作者:weixin_42576837 时间:2021-01-24 12:31:40 

什么叫模板继承呢

在我的理解就是:在前端页面中肯定有很多页面中有很多相同的地方,比如页面顶部的导航栏,底部的页脚等部分,这时候如果每一个页面都重写一遍,会很麻烦,而且也没必要。

这时候就可以做一个模板,叫做父模板,里面放上相同的部分,不同的部分先使用其他东西占位,然后在不同的页面中,继承这个父模板,不同的部分填充不同的内容。

模板页

首先做一个模板页面,模板是这样子的:

Flask模板继承深入理解与应用

上下都是不变的东西,中间的部分是不同的,不同的页面继承这个模板页,然后在中间填充不同的内容。

导航栏的两个超链接:

<li><a href="/" rel="external nofollow"  rel="external nofollow"  >首页</a></li>
<li><a href="/about" rel="external nofollow"  rel="external nofollow"  >关于我们</a></li>

注意:这里的跳转路径是指定到某一个路由,不是某一个html页面。

相同部分的代码就是普通的html代码,只有需要填充的区域代码写法不同:

首先是标题title,其他页面需要继承模板页,所以模板页的标题不能写死,而是需要动态变化的,所以需要先用一个block占位:

写法是这样的,title标签中间的内容由一个block占着,这个block叫做title,名字可以随意,后面会根据名字选择block来填充。

<title>{% block title %}{% endblock %}</title>

然后是中间区域:

<div style="background-color:silver;height: 300px;width: 500px;margin: 10px">
不同的部分
<!--中间是不同的部分,用block先占着-->
{% block body %}
{% endblock %}
</div>

这里也有一个block,叫做body。注意:每一个block都需要一个{% endblock %}作为block的结束位置。

完整代码

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <!--不同页面的标题不一样,所以需要占位符,里面的title是名称,可以随意-->
   <title>{% block title %}{% endblock %}</title>
</head>
<body>
<!--相同的部分,导航栏-->
<div style="background-color: beige;height: 200px;width: 300px">
   相同的导航栏
<ul>
   <li><a href="/" rel="external nofollow"  rel="external nofollow"  >首页</a></li>
   <li><a href="/about" rel="external nofollow"  rel="external nofollow"  >关于我们</a></li>
</ul>
</div>
<div style="background-color:silver;height: 300px;width: 500px;margin: 10px">
<p>不同的部分</p>
<!--中间是不同的部分,用block先占着-->
{% block body %}
{% endblock %}
</div>
<!--相同的部分,页脚-->
<div style="background-color: burlywood;height: 100px;width: 200px">
   <footer style="background-color: darkgray">相同的页脚部分</footer>
</div>
</body>
</html>

继承模板的页面:index.html

现在新建一个页面:index.html,它继承之前的模板页面:

由于是继承了父模板,所以首先要指定这个模板继承哪一个模板。{% extends '模板.html' %},表示继承叫做模板.html的页面。然后分别指定不同的block中填充不同的内容。

<!--继承哪一个模板-->
{% extends '模板.html' %}
<!--指定不同的内容,指定叫做title的block中的内容-->
{% block title %}
   继承了模板页的 首页
{% endblock %}
<!--指定叫做body的block中的内容-->
{% block body %}
   <p>首页中的内容</p>
{% endblock %}

这个页面对应的路由是/,对应的视图函数是:

#根路径,渲染index.html页面
@app.route('/')
def index():
   return render_template('index.html')

继承模板的页面:about.html

首先about页面对应的路由时/about,对应的视图函数:

#/about路径,渲染about.html页面
teams = ['小明','小红','小刚']
@app.route('/about')
def about():
#以关键字参数的形式把teams传递到about.html页面中
   return render_template('about.html',teams = teams)

这里我们传递一个列表过去,在about.html页面中加载出来。

about.html

{% extends '模板.html' %}
{% block title %}
继承模板页的 about页面
{% endblock %}
{% block body %}
<p>about页面中的内容</p>
   <p>
       我们的团队成员有:
       {% for name in teams %}#拿到传递的参数列表,遍历
           <li>{{ name }}</li>
       {% endfor %}
   </p>
{% endblock %}

对应的py文件:模板继承练习.py

from flask import  Flask,render_template
app = Flask(__name__,template_folder='../templates')
#根路径,渲染index.html页面
@app.route('/')
def index():
   return render_template('index.html')
#/about路径,渲染about.html页面
teams = ['小明','小红','小刚']
@app.route('/about')
def about():
   return render_template('about.html',teams = teams)
if __name__ == '__main__':
   app.run()

执行效果如下:

Flask模板继承深入理解与应用

来源:https://blog.csdn.net/weixin_42576837/article/details/126179493

标签:Flask,模板,继承
0
投稿

猜你喜欢

  • python中的集合及集合常用的使用方法

    2023-05-04 11:14:11
  • Python实现文件压缩和解压的示例代码

    2022-04-10 08:20:19
  • Python进阶之全面解读高级特性之切片

    2023-08-06 21:28:00
  • 对Python3 * 和 ** 运算符详解

    2023-08-05 10:15:27
  • Django Python 获取请求头信息Content-Range的方法

    2022-09-09 07:04:53
  • ASP访问统计计数器代码

    2008-03-20 13:33:00
  • Notice: Undefined index: page in E:\\PHP\\test.php on line 14

    2023-10-27 20:04:46
  • 简单好用的PHP分页类

    2023-11-22 09:32:39
  • Python如何实现感知器的逻辑电路

    2021-01-09 00:41:38
  • python实现人脸检测的简单实例

    2023-02-17 16:08:20
  • python中shell执行知识点

    2022-11-30 08:41:15
  • IE多版本共存的解决方案——IETester(推荐)

    2009-03-26 12:47:00
  • asp dictionary对象使用介绍

    2008-05-30 13:51:00
  • 网页设计求职全攻略

    2008-07-09 18:56:00
  • python实现百万答题自动百度搜索答案

    2021-10-06 03:57:11
  • Python实现读取文件夹按数字排序功能

    2023-08-24 02:12:45
  • Python 利用pydub库操作音频文件的方法

    2022-12-12 05:42:53
  • 详解django中视图函数的FBV和CBV

    2022-05-26 01:11:10
  • Python input函数使用实例解析

    2022-01-05 21:00:34
  • 解读python正则表达式括号问题

    2023-08-10 10:22:19
  • asp之家 网络编程 m.aspxhome.com