一、模板继承

目的是:减少代码的冗余

语法:

  1. {% block classinfo %}
  2.  
  3. {% endblock %}

具体步骤:

1、创建一个base.html文件,
2、把要显示的页面的内容写在这里面,也就是html要在浏览器显示的内容
3、在right里面写个盒子
  {% block classinfo %}

  {% endblock %}
在这里面写个空盒子,以后谁来扩展就在这个盒子里面添加相应的内容就行了

4、然后再创建一个.html文件,让这个继承base.html文件,
  {% extends "base.html" %}    #必须是在文件的第一行
  在基板里面添加内容
  {% block classinfo %}
    <h2>首页</h2>
    <h2>学生信息</h2>
    <h3>{{ class_id }}班</h3>
  {% endblock%}

5、也可以写好多盒子,
  在left中写个盒子
    {% block menu %}
      <p>I see you you</p>
    {% endblock %}

注意:
  盒子里面可以有默认的内容,如果有默认的时候你不扩展就走默认的,如果你扩展了,就替换了,
那么不替换直接追加可以嘛?可以的,那就用下面的方式。
{% block.super %}

例如:

  1. {% block menu %}
  2.  
  3.   {{ block.super }}
  4.  
  5.   <p>!!!</p> #先继承父类的,后插入数据
  6.  
  7. {% endblock %}

1、模板继承围绕两点:继承和扩展
          你有什么继承什么,       
          扩展的是盒子,
2、模板中设置的盒子越多越好,因为这样你想扩展的时候就容易了。我想扩展就扩展了。不扩展就不扩展了
3、为了更好的可读性,你也可以给你的 {% endblock %} 标签一个 名字 。例如:

  1. {% block content %}
  2. ...
  3. {% endblock content %}  

4、如果你发现你自己在大量的模版中复制内容,那可能意味着你应该把内容移动到父模版中的一个 {% block %} 中。

最后,请注意你并不能在一个模版中定义多个相同名字的 block 标签。这个限制的存在是因为block标签的作用是“双向”的。这个意思是,block标签不仅提供了一个坑去填,它还在 _父模版_中定义了填坑的内容。如果在一个模版中有两个名字一样的 block 标签,模版的父模版将不知道使用哪个block的内容。

具体例子说明

urls.py

  1. urlpatterns = [
  2. url(r'^admin/', admin.site.urls),
  3. url(r'^text/(\d+)', views.text),
  4. ]

views.py

  1. from django.shortcuts import render,redirect
  2.  
  3. # Create your views here.
  4.  
  5. def text(request,class_id):
  6. # 班级变量
  7. print(class_id) #拿到的是你在路径里输入的几就是几
  8. # 数据库查询
  9. return render(request, "text.html", {"class_id": class_id})

templaite / base.html

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width">
  7. <link rel="stylesheet" href="/static/bootstrap-3.3.7-dist/css/bootstrap.min.css">
  8. <title>Title</title>
  9. <style>
  10. .right {
  11. height: 400px;
  12. background-color: silver;
  13. }
  14. </style>
  15. </head>
  16. <body>
  17. {#导航条#}
  18. <nav class="navbar navbar-primary navbar-inverse">
  19. <div class="container-fluid">
  20. <!-- Brand and toggle get grouped for better mobile display -->
  21. <div class="navbar-header">
  22. <button type="button" class="navbar-toggle collapsed" data-toggle="collapse"
  23. data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
  24. <span class="sr-only">Toggle navigation</span>
  25. <span class="icon-bar"></span>
  26. <span class="icon-bar"></span>
  27. <span class="icon-bar"></span>
  28. </button>
  29. <a class="navbar-brand" href="#">Brand</a>
  30. </div>
  31.  
  32. <!-- Collect the nav links, forms, and other content for toggling -->
  33. <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
  34. <ul class="nav navbar-nav">
  35. <li class="active"><a href="#">Link <span class="sr-only">(current)</span></a></li>
  36. <li><a href="#">Link</a></li>
  37. <li class="dropdown">
  38. <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true"
  39. aria-expanded="false">Dropdown <span class="caret"></span></a>
  40. <ul class="dropdown-menu">
  41. <li><a href="#">Action</a></li>
  42. <li><a href="#">Another action</a></li>
  43. <li><a href="#">Something else here</a></li>
  44. <li role="separator" class="divider"></li>
  45. <li><a href="#">Separated link</a></li>
  46. <li role="separator" class="divider"></li>
  47. <li><a href="#">One more separated link</a></li>
  48. </ul>
  49. </li>
  50. </ul>
  51. </div><!-- /.navbar-collapse -->
  52. </div><!-- /.container-fluid -->
  53. </nav>
  54. {#内容#}
  55. <div class="containers">
  56. <div class="row">
  57. <div class="col-md-11 col-lg-offset-1">
  58. {# 左侧#}
  59. <div class="left col-md-3">
  60. {% block menu %}
  61. <div class="list-group">
  62. <a href="#" class="list-group-item active">
  63. 学生班级
  64. </a>
  65. <a href="/text/6" class="list-group-item">s6</a>
  66. <a href="/text/7" class="list-group-item">s7</a>
  67. <a href="/text/8" class="list-group-item">s8</a>
  68. <a href="/text/9" class="list-group-item">s9</a>
  69. </div>
  70. {% endblock %}
  71. </div>
  72. {# 右侧#}
  73. <div class="right col-md-8">
  74. {# 定义一个盒子#}
  75. {% block classinfo %}
  76. {% endblock %}
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. {#底部#}
  82.  
  83. </body>
  84. </html>

template /text.py   继承上面的文件

  1. {% extends "base.html" %}

  2. {% block classinfo %}
  3. <h1>学生信息</h1>
  4. <h3>{{ class_id }}班级</h3>
  5. {% endblock %}

  6. {#追加#}
  7. {% block menu %}
  8. {{ block.super }}
  9. <a href="">学生信息</a>
  10. {% endblock %}

二、静态文件配置

我们自己导入的一些包就叫做静态文件

1、在全局中先创建一个static的包,

2、在static里面导入我们的bootstrap,还是jquery等

3、然后在settings.py中加上一些配置

  1. STATIC_URL = '/static/' #这个配置就相当于下面配置的别名,如果这里的名字修改了就按照这里的名字去导入
  2. STATICFILES_DIRS = [
  3. os.path.join(BASE_DIR,"static") #E:\day68\static 找到static路径
  4. ]

4、导入css,js,jquery

  1. <link rel = "stysheet",href= "/static/index.css/">
  2.  
  3. <link rel="stylesheet" href="/static/bootstrap-3.3.7-dist/css/bootstrap.min.css">

Django学习:模板继承和配置静态文件的更多相关文章

  1. Django学习(6)配置静态文件

      本文将详细讲述如何在Django中配置静态文件,如图片(images),JavaScript,CSS等.   我们将要实现的网页如下: 当按下按钮"Change Text"时, ...

  2. Django 学习 之 模板(html)与配置静态文件

     一.模板(html) 1.模板语法之变量:语法为 {{ }} 在 Django 模板中遍历复杂数据结构的关键是句点字符, 语法:{{ var_name }} var_name 是一个变量名称,需要和 ...

  3. Django使用模板后无法找到静态资源文件

    Django使用模板后无法找到静态资源文件 环境配置 Django版本1.11 python版本3.6.2 前言 在编写Django网站的时候,在涉及模板方面,一些简单的例子都没有问题,但这些例子都有 ...

  4. django配置静态文件

    django配置静态文件 参考文章链接:http://blog.csdn.net/hireboy/article/details/8806098

  5. django配置静态文件的两种方法

    方法一:按照django配置静态文件的方法,可以在APP应用目录下创建一个static的文件夹,然后在static文件夹下创建一个和APP同名的文件夹,如我有一个blog的django项目,在下面有一 ...

  6. django之配置静态文件

    # 别名 STATIC_URL = '/static/' # 配置静态文件,名字必须是STATICFILES_DIRS STATICFILES_DIRS = [ os.path.join(BASE_D ...

  7. django 简易博客开发 3 静态文件、from 应用与自定义

    首先还是贴一下源代码地址  https://github.com/goodspeedcheng/sblog 上一篇博客我们介绍了 django 如何在views中使用templates以及一些常用的数 ...

  8. 第一个Django应用 - 第六部分:静态文件

    前面我们编写了一个经过测试的投票应用,现在让我们给它添加一张样式表和一张背景图片. 除了由服务器生成的HTML文件外,WEB应用一般需要提供一些其它的必要文件,比如图片文件.JavaScript脚本和 ...

  9. Django1.11.7配置静态文件

    Django配置静态文件分为三步 1.建文件夹 2.设置setting 3.页面引用 1.文件目录结构 在APP下新建static文件夹,将js和css文件放入文件夹 2.配置settings.py ...

随机推荐

  1. win32收不到F10按键消息解决的方法

    在WM_KEYDOWN中处理F10(VK_F10)消息总是获取不到,后来用spy++监听窗体消息发现按下F10并没有WM_KEYDOWN消息产生,而是产生了WM_SYSKEYDOWN

  2. 优化你的服务器Apache、MySQL、PHP

    硬件上的考虑其实起50%的作用,当然是越快越好.如果不知道哪个快,就换成越贵越好.可实际上不可能做到这些,因为银子有限,所以按照这个顺序考虑:内存越大越好->硬盘SCSI好于SATA->C ...

  3. 一起来当网管(一)——Windows Server上的DHCP配置

    学校实验室里大大小小设备还不少,网络环境虽说不复杂,但也比家用的复杂一些.就当练练手吧,刚好写点文章,免得以后实验室网络没人管了.那么就先从DHCP的配置来讲吧! 1.DHCP是什么.有什么用 DHC ...

  4. 开源项目:单行日历(CalendarView)

    http://www.cnblogs.com/warnier-zhang/p/4750525.html CalendarView.zip

  5. hibernate预编译SQL语句中的setParameter和setParameterList

    使用预编译SQL语句和占位符參数(在jdbc中是?),可以避免由于使用字符串拼接sql语句带来的复杂性.我们先来简单的看下.使用预编译SQL语句的优点. 使用String sql = "se ...

  6. MRP 中的数据元素

    20170227 MRP 元素是个什么东西? 系统显示的是MRP 元素缩写,程序用的是Code SimReq 简单需求AR 相关预订 OrdRes 订单需求BA 采购申请 PurRqs 采购申请BB ...

  7. POJ 2739 Sum of Consecutive Prime Numbers( *【素数存表】+暴力枚举 )

    Sum of Consecutive Prime Numbers Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 19895 ...

  8. HDU3081 Marriage Match II —— 传递闭包 + 二分图最大匹配 or 传递闭包 + 二分 + 最大流

    题目链接:https://vjudge.net/problem/HDU-3081 Marriage Match II Time Limit: 2000/1000 MS (Java/Others)    ...

  9. 通过xmanager连接Linux图形界面

    今天要在linux下安装数据库,用的是xmanager:之前自己也用过该工具在OUI下做过安装,还很顺利. 但是,今天连接后,运行命令,等了有5分钟,没有出现OUI界面. linux版本: [root ...

  10. 全排列 STL

    #include<iostream> #include<algorithm> #include<stdio.h> using namespace std; int ...