模板的常用标签
模板标签的作用: 标签在渲染的过程中提供任意的逻辑
标签语法: 由%} 和 {% tag %}{% endtag %}
写一个模板标签
每一个模板标签都需要有一个结束标签{% if %} {% endif %}
效果图
如上图,给上图加序号
效果图
模板标签url反向解析
在teacher urls.py文件中配置一下路径
效果图
实现点击跳转到学生的详情页
效果图
注意:这种方式是写死的,如果需要修改就很麻烦.
利用另一个方法
name相当于“给网址取了个名字”,只要这个名字不变,网址变了也能通过名字获取到。
自动去解析
最后效果还是一样的.
模板的继承和引用
新建了一个base基类
把student_list_page.html的内容复制到了base.html
如果需要,写足够多的 block 以便继承的模板可以重写该部分,include 是包含其它文件的内容,就是把一些网页共用的部分拿出来,重复利用,改动的时候也方便一些,还可以把广告代码放在一个单独的html中,改动也方便一些,在用到的地方include进去。其它的页面继承自 base.html 就好了,继承后的模板也可以在 block 块中 include 其它的模板文件。
我们这里写了两个block
并在使用了extends在student_list_page.html里面继承了base
效果图
注意:模板一般放在app下的templates中,Django会自动去这个文件夹中找。但 假如我们每个app的templates中都有一个 index.html,当我们在views.py中使用的时候,直接写一个 render(request, 'index.html'),Django 能不能找到当前 app 的 templates 文件夹中的 index.html 文件夹呢?(答案是不一定能,有可能找错)
Django 模板查找机制: Django 查找模板的过程是在每个 app 的 templates 文件夹中找(而不只是当前 app 中的代码只在当前的 app 的 templates 文件夹中找)。各个 app 的 templates 形成一个文件夹列表,Django 遍历这个列表,一个个文件夹进行查找,当在某一个文件夹找到的时候就停止,所有的都遍历完了还找不到指定的模板的时候就是 Template Not Found (过程类似于Python找包)。这样设计有利当然也有弊,有利是的地方是一个app可以用另一个app的模板文件,弊是有可能会找错了。所以我们使用的时候在 templates 中建立一个 app 同名的文件夹,这样就好了。
这就需要把每个app中的 templates 文件夹中再建一个 app 的名称,仅和该app相关的模板放在 app/templates/app/ 目录下面,
效果图
一样的也能继承,这样更方便的,祛除了更多的冗余代码(相同的部分)
模板引用
实现标签内容的闪烁
在详情页引入ad.heml实现效果
(注:有些专业解释来自Django自强学堂)