返回顶部
首页 > 资讯 > 后端开发 > Python >Flask模板继承深入理解与应用
  • 604
分享到

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

2024-04-02 19:04:59 604人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录什么叫模板继承呢模板页完整代码什么叫模板继承呢 在我的理解就是:在前端页面中肯定有很多页面中有很多相同的地方,比如页面顶部的导航栏,底部的页脚等部分,这时候如果每一个页面都重写一

什么叫模板继承呢

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

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

模板页

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

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

导航栏的两个超链接:

<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模板继承深入理解与应用的文章就介绍到这了,更多相关Flask模板继承内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Flask模板继承深入理解与应用

本文链接: https://lsjlt.com/news/120302.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Flask模板继承深入理解与应用
    目录什么叫模板继承呢模板页完整代码什么叫模板继承呢 在我的理解就是:在前端页面中肯定有很多页面中有很多相同的地方,比如页面顶部的导航栏,底部的页脚等部分,这时候如果每一个页面都重写一...
    99+
    2024-04-02
  • Django模板继承与模板的导入实例详解
    目录一:模版的继承1.什么是模板继承2.使用继承流程原理3.模板继承语法二:模板的继承使用1.案例需求2.总结模板继承三:模版的导入1.模板导入2.模板导入格式3.模板导入使用4.使...
    99+
    2024-04-02
  • 深入理解C#之继承
    目录C#之继承能够阻止某个类被其他类继承吗?那么我们该如何获得基类的构造函数和自身的构造函数呢?都定义有构造函数时,那么执行顺序会怎样呢?总结C#之继承 继承、封装和多态是面向对象编...
    99+
    2024-04-02
  • C++中的继承模式深入详解
    前言 继承是OOP设计中的重要概念。在C++语言中,派生类继承基类有三种继承方式:私有继承(private)、保护继承(protected)和公有继承(public)。 一、继承...
    99+
    2024-04-02
  • django中模板继承与ModelForm怎么用
    这篇文章主要讲解了“django中模板继承与ModelForm怎么用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“django中模板继承与ModelForm怎么用”吧!模板的继承完美在写ht...
    99+
    2023-06-30
  • django中模板继承与ModelForm实例详解
    目录模板的继承form和ModelForm使用方法总结模板的继承 完美在写html的时候会发现,自己多个html文件中又好多东西是一样的,包括静插件的引入 还有有些简单的css样式都...
    99+
    2024-04-02
  • C++继承的赋值转换与菱形虚拟继承深入详解
    目录一、继承的概念及定义1.1、继承的概念1.2、继承的定义二、基类和派生类对象赋值转换三、继承中的作用域3.1、继承同名成员处理方式3.2、继承同名静态成员处理方式3.3、继承与友...
    99+
    2022-11-13
    C++继承的赋值转换 C++菱形虚拟继承
  • C++深入探究继承的概念与使用
    目录1、概念及定义1.1 概念1.2 定义2、class与struct的区别3、赋值兼容规则4、继承中的作用域问题5、派生类(子类)的默认成员函数5.1 构造函数5.2 拷贝构造函数...
    99+
    2024-04-02
  • C++模板编程的深入理解
    什么是模板编程?模板编程是使用类型参数泛型化算法和数据结构,并生成可在编译时处理多种数据类型的代码。关键概念:模板函数和类:使用 template 关键字创建,接受类型参数,处理不同类型...
    99+
    2024-05-21
    c++ 模板编程
  • Python 继承与多态:深入理解面向对象编程的基石
    继承 继承是面向对象编程中的一种关系,允许派生类(子类)继承其父类的属性和方法。通过继承,派生类可以复用父类的代码,减少重复代码并促进代码组织。 在Python中,使用class关键字创建类,并使用super()内置函数实现继承。例如:...
    99+
    2024-02-19
    Python 继承 多态 面向对象编程 派生类 方法覆盖 重用性 灵活性
  • Java 对象的面纱:深入理解封装和继承
    封装 封装是一个保护机制,它将对象的内部状态和行为隐藏起来,只允许通过明确定义的接口访问它们。这种机制提供了以下优势: 信息隐藏: 防止外部代码意外更改对象的状态或行为,增强安全性。 数据完整性: 确保对象状态始终保持一致,防止不一致或...
    99+
    2024-03-12
    在面向对象编程 (OOP) 理解封装和继承对于构建健壮且可维护的应用程序至关重要。封装和继承是 OOP 的两个基本概念 它们共同为对象提供了一个保护和组织结构。
  • C++ 函数继承详解:如何使用模板继承来实现泛型代码复用?
    c++++ 函数继承通过模板继承实现泛型代码复用,允许创建通用函数模板,然后继承更具体的函数,定制不同的数据类型行为。代码示例包括打印容器函数,通过继承定制打印整数和字符串容器。函数继承...
    99+
    2024-05-04
    c++ 函数继承
  • Python多继承的实现与应用解析
    解析Python中多继承的原理与实践在Python的面向对象编程中,多继承是一种非常强大且灵活的特性。通过多继承,一个类可以从多个父类中继承属性和方法,从而更好地实现代码的复用和功能的组合。本文将解析Python中多继承的原理,并通过具体的...
    99+
    2023-12-30
    Python 多继承 原理与实践
  • C++深入了解模板的使用
    目录一.泛型编程二.函数模板1.函数模板概念2.函数模板格式3.函数模板的原理三.类模板一.泛型编程 泛型编程:不再是针对某种类型,能适应广泛的类型,跟具体的类型无关的代码 如何实现...
    99+
    2024-04-02
  • 深入解析Gotemplate模板使用详解
    本文只关注Go text/template的底层结构,带上了很详细的图片以及示例帮助理解,有些地方也附带上了源码进行解释。有了本文的解释,对于Go template的语法以及html...
    99+
    2024-04-02
  • Java 封装与继承:理解、应用,成为编程大师
    封装和继承是面向对象编程(OOP)的两大基石,理解和应用它们对 Java 开发人员至关重要。通过封装,我们可以隐藏对象的内部状态和行为,从而提高代码的安全性、可维护性和可重用性。继承则允许我们创建新的类,这些类继承自现有类的特性和行为,从...
    99+
    2024-04-02
  • 深入理解 JavaScript 原型链:对象继承的秘密武器
    JavaScript 中,每个对象都具有一个原型对象,原型对象也是一个对象。原型对象包含了一些公共属性和方法,这些属性和方法可以被所有由该对象创建的子对象继承。这种继承方式称为原型链继承。 二、原型链的优点 代码重用:由于父对象的所有属...
    99+
    2024-02-06
    JavaScript 原型链概述
  • 如何理解CSS继承性及其应用
    这期内容当中小编将会给大家带来有关如何理解CSS继承性及其应用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。你对CSS继承性的概念和使用是否了解,这里和大家分享一下,CS...
    99+
    2024-04-02
  • 深入理解Java设计模式之模板方法模式
    目录一、什么是模板方法模式二、模板方法模式的使用场景三、模板方法模式的优缺点四、模板方法模式的实现五、总结一、什么是模板方法模式 模板方法模式在一个方法中定义一个算法的骨架,而将一些...
    99+
    2024-04-02
  • Java 生命周期中封装和继承的应用:深入理解对象创建和销毁
    封装在 Java 生命周期中的应用 对象创建:通过构造方法实例化对象时,对象的内部状态被初始化并隐藏。 对象访问:通过 getter 和 setter 方法获取或修改对象的属性,而无需直接访问其内部数据。 对象销毁:当对象不再需要时,它...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作