美文网首页
Django模板[介绍]

Django模板[介绍]

作者: 錦魚 | 来源:发表于2018-10-31 18:44 被阅读0次

    模板

    作为Web框架,Django提供了模板,用于编写html代码,还可以嵌入模板代码更快更方便的完成页面开发,再通过在视图中渲染模板,将生成最终的html字符串返回给客户端浏览器。模版致力于表达外观,而不是程序逻辑。模板的设计实现了业务逻辑view与显示内容template的分离,一个视图可以使用任意一个模板,一个模板可以供多个视图使用。

    模板包含两部分:

    • 静态部分,包含html、css、js。
    • 动态部分,就是模板语言。

    Django模板语言,简写DTL,定义在django.template包中。 创建项目后,在"项目名称/settings.py"文件中定义了关于模板的配置。

    DIRS定义一个目录列表,模板引擎按列表顺序搜索这些目录以查找模板文件,通常是在项目的根目录下创建templates目录。

    Django处理模板分为两个阶段:

    • 1.加载:根据给定的路径找到模板文件,编译后放在内存中。
    • 2.渲染:使用上下文数据对模板插值并返回生成的字符串。

    为了减少开发人员重复编写加载、渲染的代码,Django提供了简写函数render,用于调用模板。

    创建示例项目

    • 1)创建项目test4。

    django-admin startproject test4

    • 2)进入项目目录test4,创建应用booktest。

    cd test4
    python manage.py startapp booktest

    • 4)在test4/settings.py中INSTALLED_APPS项安装应用。
    • 5)在test4/settings.py中DATABASES项配置使用MySQL数据库test2,数据库在第二部分已经创建。
    • 6)在test4/settings.py中TEMPLATES项配置模板查找路径。
    • 7)创建模板目录结构如下。
    • 8)打开test4/urls.py文件,包含booktest的url配置。
    • 9)在booktest/目录下创建urls.py,配置url。
    from django.conf.urls import url
    from booktest import views
    urlpatterns=[
        url(r'^$',views.index),
    ]
    
    • 10)打开booktest/views.py文件,定义视图index。
    from django.shortcuts import render
    
    def index(request):
        return render(request,'booktest/index.html')
    
    • 11)在templates/booktest目录下创建文件index.html,代码如下:
    <html>
    <head>
        <title>首页</title>
    </head>
    <body>
    
    </body>
    </html>
    
    • 12)打开booktest/models.py文件,定义模型类BookInfo,结构参照之前的设计。
    from django.db import models
    
    class BookInfo(models.Model):
        btitle = models.CharField(max_length=20)
        bpub_date = models.DateField()
        bread = models.IntegerField(default=0)
        bcommet = models.IntegerField(default=0)
        isDelete = models.BooleanField(default=False)
    

    模板语言

    模板语言包括4种类型,分别是:

    变量
    标签
    过滤器
    注释

    接下来逐个介绍4种类型。


    模板变量

    模板变量的作用是计算并输出,变量名必须由字母、数字、下划线(不能以下划线开头)和点组成。

    语法如下:

    {{变量}}

    当模版引擎遇到点如book.title,会按照下列顺序解析:

    1.字典book['title']
    2.先属性后方法,将book当作对象,查找属性title,如果没有再查找方法title()
    3.如果是格式为book.0则解析为列表book[0]

    • 如果变量不存在则插入空字符串''。

    在模板中调用方法时不能传递参数。

    示例
    1)打开booktest/views.py文件,创建视图temp_var。
    def temp_var(request):
        dict={'title':'字典键值'}
        book=BookInfo()
        book.btitle='对象属性'
        context={'dict':dict,'book':book}
        return render(request,'booktest/temp_var.html',context)
    
    2)打开booktest/urls.py文件,配置url。
    url(r'^temp_var/$', views.temp_var),
    
    3)修改在templates/booktest下创建temp_var.html。
    <html>
    <head>
        <title>模板变量</title>
    </head>
    <body>
        模板变量:<br/>
        {{dict.title}}<br/>
        {{book.btitle}}<br/>
    </body>
    </html>
    
    4)运行服务器,在浏览器中输入如下网址。
    http://127.0.0.1:8000/temp_var/
    

    标签

    语法如下:

    {%代码段%}

    for标签语法如下:

    {%for item in 列表%}

    循环逻辑
    {{forloop.counter}}表示当前是第几次循环,从1开始
    {%empty%}
    列表为空或不存在时执行此逻辑
    {%endfor%}

    if标签语法如下:

    {%if ...%}
    逻辑1
    {%elif ...%}
    逻辑2
    {%else%}
    逻辑3
    {%endif%}

    比较运算符如下:

    注意:运算符左右两侧不能紧挨变量或常量,必须有空格。

    ==
    !=
    <

    <=

    =

    布尔运算符如下:

    and
    or
    not

    示例

    1)打开booktest/views.py文件,创建视图temp_tag。
    from booktest.models import BookInfo
    def temp_tags(request):
        context={'list':BookInfo.objects.all()}
        return render(request,'booktest/temp_tag.html',context)
    
    2)打开booktest/urls.py文件,配置url。
    url(r'^temp_tag/$',views.temp_tags),
    
    3)在templates/booktest下创建temp_tag.html。
    <html>
    <head>
        <title>标签</title>
    </head>
    <body>
        图书列表如下:
        <ul>
            {%for book in list%}
                {%if book.id <= 2%}
                    <li style="background-color: red;">{{book.btitle}}</li>
                {%elif book.id <= 3%}
                    <li style="background-color: blue;">{{book.btitle}}</li>
                {%else%}
                    <li style="background-color: green;">{{book.btitle}}</li>
                {%endif%}
            {%empty%}
                <li>对不起,没有图书</li>
            {%endfor%}
        </ul>
    </body>
    </html>
    
    4)运行服务器,在浏览器中输入如下网址。
    http://127.0.0.1:8000/temp_tag/
    

    过滤器

    语法如下:

    • 使用管道符号|来应用过滤器,用于进行计算、转换操作,可以使用在变量、标签中。
    • 如果过滤器需要参数,则使用冒号:传递参数。
    • 变量|过滤器:参数
      长度length,返回字符串包含字符的个数,或列表、元组、字典的元素个数。
      默认值default,如果变量不存在时则返回默认值。

    data|default:'默认值'

    日期date,用于对日期类型的值进行字符串格式化,常用的格式化字符如下:

    • Y表示年,格式为4位,y表示两位的年。
    • m表示月,格式为01,02,12等。
    • d表示日, 格式为01,02等。
    • j表示日,格式为1,2等。
    • H表示时,24进制,h表示12进制的时。
    • i表示分,为0-59。
    • s表示秒,为0-59。

    value|date:"Y年m月j日 H时i分s秒"

    <hr5>

    自定义过滤器

    过滤器就是python中的函数,注册后就可以在模板中当作过滤器使用,下面以求余为例开发一个自定义过滤器mod。

    示例
    1)在应用中创建templatetags目录,当前示例为"booktest/templatetags",创建_init_文件,内容为空。
    2)在"booktest/templatetags"目录下创建filters.py文件,代码如下:
    #导入Library类
    from django.template import Library
    
    #创建一个Library类对象
    register=Library()
    
    #使用装饰器进行注册
    @register.filter
    #定义求余函数mod,将value对2求余
    def mod(value):
        return value%2 == 0
    

    3)在templates/booktest/temp_filter.html中,使用自定义过滤器。

    • 首先使用load标签引入模块。
      加载:{%load filters%}
      使用:{%属性 | 函数名%}

    注释

    在模板中使用如下模板注释,这段代码不会被编译,不会输出到客户端;html注释只能注释html内容,不能注释模板语言。

    1)单行注释语法如下:

    {#...#}
    注释可以包含任何模版代码,有效的或者无效的都可以。

    {# { % if foo % }bar{ % else % } #}

    2)多行注释使用comment标签,语法如下:

    {%comment%}
    ...
    {%endcomment%}

    相关文章

      网友评论

          本文标题:Django模板[介绍]

          本文链接:https://www.haomeiwen.com/subject/uyratqtx.html