Django模板层(template)

Posted 王之迷惑

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django模板层(template)相关的知识,希望对你有一定的参考价值。

1、模板是一个文本,用于分离文档的表现形式和内容。也可以说是:HTML代码+模板语法

     简单的例子:使用模板在页面显示“hello word”     

      在template中新建html文件:hello.html,  在views.py中添加对象,向模板中提交数据。在urls.py中添加url与函数对象的映射关系

<h1>{{ hello }}</h1>
hello.html
from django.shortcuts import render,redirect,HttpResponse

def hello(request):
    context={}
    context[\'hello\'] = \'Hello World!\'
    return render(request, \'hello.html\', context)
views.py
urlpatterns = [
    url(r\'^admin/\', admin.site.urls),
    url(r\'^hello/\', views.index),

]
urls.py

     访问:http://127.0.0.1:8000/hello 的到如下结果

       

     这样我们就完成了使用模板来输出数据,从而实现数据与视图分离。

 

2、模板语法之变量:

     在模板中变量的语法:用双大括号  {{ var_name }}

     例:在views.py的变量形式     

def index(request):
    import datetime
    s="hello"
    l=[111,222,333]    # 列表
    dic={"name":"yuan","age":18}  # 字典
    date = datetime.date(1993, 5, 2)   # 日期对象
 
    class Person(object):
        def __init__(self,name):
            self.name=name
 
    person_yuan=Person("yuan")  # 自定义类对象
    person_egon=Person("egon")
    person_alex=Person("alex")
 
    person_list=[person_yuan,person_egon,person_alex]
 
 
    return render(request,"index.html",{"l":l,"dic":dic,"date":date,"person_list":person_list}) 

  在template中的变量形式:

<h4>{{s}}</h4>
<h4>列表:{{ l.0 }}</h4>
<h4>列表:{{ l.2 }}</h4>
<h4>字典:{{ dic.name }}</h4>
<h4>日期:{{ date.year }}</h4>
<h4>类对象列表:{{ person_list.0.name }}</h4>

3、模板之过滤器

     语法:{{obj|filter__name:param}}

     default:如果一个变量是false或者为空,使用给定的默认值。否则,使用变量的值。例如:{{ value|default:"nothing" }}

     length:返回值的长度。它对字符串和列表都起作用。例如:{{ value|length }}

     filesizeformat:将值格式化为一个 “人类可读的” 文件尺寸 (例如 \'13 KB\'\'4.1 MB\'\'102 bytes\', 等等)。例如:{{ value|filesizeformat }}

     date:将值按照给定的方式格式化。{{ value|date:"Y-m-d" }} 

     safe:Django的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,比如我们做一个内                容管理系统,后台添加的文章中是经过修饰的,这些修饰可能是通过一个类似于FCKeditor编辑加注了HTML修饰符的文本,如果自动转义的话显示的就是保护HTML标签的                源文件。为了在Django中关闭HTML的自动转义有两种方式,如果是一个单独的变量我们可以通过过滤器“|safe”的方式告诉Django这段代码是安全的不必转义。比如:

        value="<a href="">点击</a>"

              {{ value|safe}}

4、模板之标签:

     for标签:遍历每一个元素,  语法:                   

{% for person in person_list %}
    <p>{{ person.name }}</p>
{% endfor %}

  for...empty标签:for 标签带有一个可选的{% empty %} 从句,以便在给出的组是空的或者没有被找到时,可以有所操作。

{% for person in person_list %}
    <p>{{ person.name }}</p>

{% empty %}
    <p>sorry,no person here</p>
{% endfor %}

  if标签:{% if %}会对一个变量求值,如果它的值是“True”(存在、不为空、且不是boolean类型的false值),对应的内容块会输出。

{% if num > 100 or num < 0 %}
    <p>无效</p>
{% elif num > 80 and num < 100 %}
    <p>优秀</p>
{% else %}
    <p>凑活吧</p>
{% endif %}

  with标签:使用一个简单地名字缓存一个复杂的变量,当你需要使用一个“昂贵的”方法(比如访问数据库)很多次的时候是非常有用的

{% with total=business.employees.count %}
    {{ total }} employee{{ total|pluralize }}
{% endwith %}

5、自定义标签和过滤器:     

     1>  在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag.

     2>  在app中创建templatetags模块(模块名只能是templatetags)

     3>  创建任意 .py 文件,如:my_tags.py           

from django import template
from django.utils.safestring import mark_safe
 
register = template.Library()   #register的名字是固定的,不可改变
#以上内容是固定格式。

@register.filter     #定义一个过滤器       
def filter_multi(x,y): #实现一个简单的乘法函数 
return x * y

@register.simple_tag #定义一个标签
def multi(x,y):  
return x * y

  

     4>  在使用自定义simple_tag和filter的html文件中导入之前创建的 my_tags.py

           {% load my_tags %}

     5>  使用simple_tag和filter(如何调用)

            num=10

           {{ num|filter_multi:2 }}      #经过调用得:20

     注意:filter可以用在if等语句后,simple_tag不可以。filter只能接收两个参数。

6、模板继承:

      Django模版引擎中最强大也是最复杂的部分就是模版继承,模板继承简单理解为通过继承的方法实现模板(base.html)复用。

      简单的例子:以下文件base.html为模板文件,文件中 {% block mainbody %}   {% endblock %} 内需要补充自己需要的内容,子模版可能会覆盖掉模版中的这些位置。  

 1 <!DOCTYPE html>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title></title>
 6 </head>
 7 <body>
 8     <h1>Hello World!</h1>
 9     {% block mainbody %}
10 
11     {% endblock %}
12 </body>
13 </html>

       下面的文件为继承base.html 

1 {% extends "base.html" %}
2  
3 {% block mainbody %}<p>继承了 base.html 文件</p>
4 {% endblock %}

 输出结果:

   

 

    

 

     

     

     

         

以上是关于Django模板层(template)的主要内容,如果未能解决你的问题,请参考以下文章

Django模板层(template)

django-template层

Django——模板层(template)(模板语法自定义模板过滤器及标签模板继承)

微信小程序视图层WXML_模板

python--Django之模板层(template)

55.django模板层(templates)