一、继承的实现
data:image/s3,"s3://crabby-images/2d577/2d577b1d7842a48b3aa0ea81c2fa5618def2cc02" alt=""
image.png
data:image/s3,"s3://crabby-images/8e0d5/8e0d5acd40750a287bb1ba45872e52d71a2edf06" alt=""
image.png
data:image/s3,"s3://crabby-images/37a5d/37a5d7b5bea768681907a3db9a8cab0853af7681" alt=""
image.png
二、目录结构和代码
data:image/s3,"s3://crabby-images/10cb4/10cb4e6a095ea3fef2abc4ef0e2326bac081811b" alt=""
image.png
app.py
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/')
def index():
""" 首页 """
return render_template('index.html')
@app.route('/course')
def course():
""" 免费课程 """
return render_template('course.html')
@app.route('/coding')
def coding():
""" 实战课程 """
return render_template('coding.html')
@app.route('/article')
def article():
""" 手记 """
return render_template('article.html')
@app.route('/wenda')
def wenda():
""" 实战课程 """
return render_template('wenda.html')
if __name__ == '__main__':
app.run(debug=True)
公共部分--base.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>首页-慕课网</title>
<style type="text/css">
.container {
width: 600px;
height: 500px;
margin: 0 auto;
}
header {
background: aqua;
}
article {
background: azure;
height: 500px;
}
footer {
background-color: coral;
}
</style>
</head>
<body>
<div class="container">
<header>
页面头部[首页 免费课程 实战课程 金职位 专栏 猿问 手记]
</header>
<article>
{% block content %}
首页课程内容
{% endblock %}
</article>
<footer>页面底部</footer>
</div>
</body>
</html>
继承页面:首页-index.html
{% extends 'base.html' %}
{% block content %}
首页课程内容
{% endblock %}
data:image/s3,"s3://crabby-images/90b47/90b47a572081ba1cbb6b51ce2899ddf7fae13908" alt=""
image.png
继承页面:免费课程:course.html
{% extends 'base.html' %}
{% block content %}
免费课程内容
{% endblock %}
data:image/s3,"s3://crabby-images/6dbc7/6dbc761ae50e0e27f4380f1e7b95d197150e6880" alt=""
image.png
三、复用父模板的内容(可选)
data:image/s3,"s3://crabby-images/5f3cf/5f3cf14803237855ecef5772345e329837d5fa8e" alt=""
image.png
base.html该部分对header进行了更改
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>首页-慕课网</title>
<style type="text/css">
.container {
width: 600px;
height: 500px;
margin: 0 auto;
}
header {
background: aqua;
}
article {
background: azure;
height: 500px;
}
footer {
background-color: coral;
}
</style>
</head>
<body>
<div class="container">
<header>
{% block header %}
页面头部[首页 免费课程 实战课程 金职位 专栏 猿问 手记]
{% endblock %}
</header>
<article>
{% block content %}
<p>
课程内容
</p>
{% endblock %}
</article>
<footer>页面底部</footer>
</div>
</body>
</html>
index.html:首页的header,进行了变更,并且content部分进行了super().注意查看效果
{% extends 'base.html' %}
{% block header%}
首页的顶部导航
{% endblock %}
{% block content %}
{{ super() }}
<p>
首页课程内容
</p>
{% endblock %}
data:image/s3,"s3://crabby-images/f92a5/f92a5f23bfbdada6d9a559fc65383619f46414d1" alt=""
image.png
网友评论