• 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 %}

     输出结果:

       

        

         

         

         

             

  • 相关阅读:
    Python+selenium+unittest的GUI自动化框架实现
    新手学习selenium路线图(老司机亲手绘制)学前篇(转上海悠悠)
    jmeter需要登录才会返回的接口验证
    python、java大作战,python测试dubbo接口
    eclipse生成doc文件乱码
    读书笔记:读完互联网测试经验的感受
    关于全功能团队及测试人员的发展
    一个Junit做单元测试的简单例子
    python搭建简单的web服务器
    我的第一篇博客
  • 原文地址:https://www.cnblogs.com/brightbrother/p/7841480.html
Copyright © 2020-2023  润新知