Django HTML模版

一个网站的基本框架(如页面布局、导航栏、页脚栏等)往往是相同的。可以把这个基本框架做成一个模版,其它正式的HTML页面可以直接套用这个模版,可以大减少各HTML文件的代码量。

语法(模版文件中):

html 复制代码
{% block content1 %}
	<!--创建一个块,其它HTML文件可以些区间填充内容,content1为块的名称,一个模版文件可以创建多个块-->
{% endblock %}

语法(其它HTML文件中):

html 复制代码
<!--引用layout.html模版-->
{% extends '模版示例/layout.html' %}
{% block content1 %}
	<!-- 这在个区域里填充HTML代码,content1为块的名称,需要和模版文件中的对应 -->
	
{% endblock %}

示例:

1)创建一个模版页面

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>模版示例</title>
		<style>
			#nav{
				width: 1280px;
				height: 100px;
				background-color: aqua;
				
			}
			#foot{
				width: 1280px;
				height: 100px;
				background-color: blue;
				
			}
		</style>
		{% block content1 %}
					<!--创建一个块,可用于写一些CSS等-->
		{% endblock %}
	</head>
	<body>
		<div id='nav'>
			<h1>导航区</h1>
		</div>
		<div>
			<h1>内容区</h1>
			{% block content2 %}
						<!--创建一个块,可用于写网页的实际内容-->
			{% endblock %}
		</div>
		<div id='foot'>
			<h1>页脚区</h1>
		</div>
		{% block content3 %}
					<!--创建一个块,可用于写js代码等内容-->
		{% endblock %}
	</body>
</html>

模版页面效果:

2)正式HTML文件引用模版

page1.html

html 复制代码
<!--引用layout.html模版-->
{% extends '模版示例/layout.html' %}
{% block content1 %}
	<!-- 填充第一个block -->
	<style>
		h2{
			color: red;
		}
	</style>
{% endblock %}

{% block content2 %}
	<!-- 填充第二个block -->
	<h2>我是page1,我引入了模版的内容</h2>
{% endblock %}

页面效果:

page2.html

html 复制代码
<!--引用layout.html模版-->
{% extends '模版示例/layout.html' %}
{% block content1 %}
	<!-- 填充第一个block -->
	<style>
		h2{
			color: pink;
		}
	</style>
{% endblock %}

{% block content2 %}
	<!-- 填充第二个block -->
	<h2>我是page2,我引入了模版的内容</h2>
{% endblock %}

页面效果:

这里我们发现,page1和page2的导航区和页脚区的内容都是一样的,是从模版中引入的,只需要写填充内容区即可。代码量大大减少。

而且,如果需要修改导航区和页脚区的内容,只需要修改模版文件即可。

相关推荐
Captain823Jack26 分钟前
nlp新词发现——浅析 TF·IDF
人工智能·python·深度学习·神经网络·算法·自然语言处理
资源补给站1 小时前
大恒相机开发(2)—Python软触发调用采集图像
开发语言·python·数码相机
Captain823Jack1 小时前
w04_nlp大模型训练·中文分词
人工智能·python·深度学习·神经网络·算法·自然语言处理·中文分词
PieroPc1 小时前
Python 自动化 打开网站 填表登陆 例子
运维·python·自动化
真的很上进2 小时前
如何借助 Babel+TS+ESLint 构建现代 JS 工程环境?
java·前端·javascript·css·react.js·vue·html
VinciYan2 小时前
基于Jenkins+Docker的自动化部署实践——整合Git与Python脚本实现远程部署
python·ubuntu·docker·自动化·jenkins·.net·运维开发
测试老哥2 小时前
外包干了两年,技术退步明显。。。。
自动化测试·软件测试·python·功能测试·测试工具·面试·职场和发展
終不似少年遊*2 小时前
美国加州房价数据分析01
人工智能·python·机器学习·数据挖掘·数据分析·回归算法
如若1233 小时前
对文件内的文件名生成目录,方便查阅
java·前端·python
西猫雷婶3 小时前
python学opencv|读取图像(二十一)使用cv2.circle()绘制圆形进阶
开发语言·python·opencv