Django丨模块

Django模块


在HelloWorld目录下创建templayes目录,并建立hello.html文件

HelloWorld/
|-- HelloWorld
|   |-- __init__.py
|   |-- __init__.pyc
|   |-- settings.py
|   |-- settings.pyc
|   |-- urls.py
|   |-- urls.pyc
|   |-- views.py
|   |-- views.pyc
|   |-- wsgi.py
|   `-- wsgi.pyc
|-- manage.py
`-- templates
    `-- hello.html

hello.html文件代码

<h1>{{ hello }}</h1>

模板中变量使用双括号

建好模板之后还需说明模板文件路径,修改HelloWorld/settings.py,修改中TEMPLATES中的DIRS。

...TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [
        os.path.join(BASE_DIR, 'templates)
        ],       # 修改位置
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]
...
Django模板标签

变量

模板语法

view:{"HTML变量名" : "views变量名"}
HTML:{{变量名}}

HelloWorld/HelloWorld/views/py文件

from django.shortcuts import render

def runoob(request):
  views_name = "world"
  return  render(request,"runoob.html", {"name":views_name})

templates中的hello.html

<p>{{ name }}</p>
列表

templates中的hello.html中,可以用.索引下标取出对应的元素。

from django.shortcuts import render

def runoob(request):
    views_list = ["wordl1","world2","world3"]
    return render(request, "hello.html", {"views_list": views_list})

HelloWorld/templates/hello.html文件代码:

<p>{{ views_list }}</p>   # 取出整个列表
<p>{{ views_list.0 }}</p> # 取出列表的第一个元素
字典

templates中的runoob.html中,可以用.键取出对应的值

from django.shortcuts import render

def runoob(request):
    views_dict = {"name":"world"}
    return render(request, "runoob.html", {"views_dict": views_dict})

HelloWorld/templayes/hello.html文件代码

<p>{{ views_dict }}</p>
<p>{{ views_dict.name }}</p>
过滤器

模板语法

{{ 变量名 | 过滤器:可选参数 }}

模板过滤器可以在变量被显示前修改它,过滤器使用管道字符

{{ name|lower }}

{{ name }}变量被过滤器lower处理后,文档大写转换文本为小写。

过滤管道可以被“套接”,即是说,一个过滤器管道的输出又可以作为下一个管道的输入

# 将第一个元素转换为大写
{{ my_list|first|upper }}

其他过滤器

  • addslashes:添加反斜杠到任何反斜杠、单引号或者双引号前面
  • date:按指定的格式字符串参数格式化date或者datetime对象
{{ pub_date|date:"F j, Y" }}
  • length:返回变量的长度

  • default
    default为变量提供一个默认值

如果views传的变量的布尔值是false,则使用指定的默认值

HelloWorld/HelloWorld/views.py文件代码

from django.shortcuts import render

def runoob(request):
    name =0
    return render(request, "hello.html", {"name": name})

HelloWorld/templates/hello.html

{{ name|default:"world" }}
  • filesizeformat
    以更易读的方式显示文件的大小(即13KB,4.1MB等)

  • safe

将字符串标记为安全,不需要转义。

要保证views.py传过来的数据绝对安全,才能用safe。和后端views.py的mark_safe效果相同。

Django会自动对views.py传到HTML文件中的标签语法进行转义,令其语义失效。

加safe过滤器是告诉Django该数据是安全的,不必对器进行转义,可以让该数据语义生效。

HelloWorld/HelloWorld/views.py文件代码

from django.shortcuts import render

def runoob(request):
    views_str = "<a href='https://www.baidu.com/'>点击跳转</a>"
    return render(request, "hello.html", {"views_str": views_str})

HelloWorld/templates/hello.html

{{ views_str|safe }}
if/else标签

基本语法格式如下

{% if condition %}
     ... display
{% endif %}

或者

{% if condition1 %}
   ... display 1
{% elif condition2 %}
   ... display 2
{% else %}
   ... display 3
{% endif %}

根据条件判读是否输出,支持嵌套

HelloWorld/HelloWorld/views.py文件代码

from django.shortcuts import render

def runoob(request):
    views_num = 88
    return render(request, "hello.html", {"num": views_num})

HelloWorld/templates/hello.html

{%if num > 90 and num <= 100 %}
优秀
{% elif num > 60 and num <= 90 %}
合格
{% else %}
一边玩去~
{% endif %}
for标签

{% for %}允许在一个序列上迭代

与Python的for语句的情形类似。

每一次循环中,模块系统会渲染在{% for %}和{% endfor %}之间的所有内容。

{% for i in views_list %}
{{ i }}
{% endfor %}

遍历字典可以直接用字典**.items**方法,用变量的解包分别获取键和值。

{% for i,j in views_dict.items %}
{{ i }}---{{ j }}
{% endfor %}

在{% for %}标签里可以通过{{ forloop }}变量获取循环序号。

  • forloop.counter 顺序获取循环序号,从1开始计算
  • forloop.counter() 顺序获取循环序号,从0开始计算
{% for i in listvar %}
    {{ forloop.counter }}  # 顺序获取循环序号,从 1 开始计算
    {{ forloop.counter0 }}  # 顺序获取循环序号,从 0 开始计算
    {{ forloop.revcounter }}  #倒叙获取循环序号,结尾序号为 1
    {{ forloop.revcounter0 }}  # 倒叙获取循环序号,结尾序号为 0
    {{ forloop.first }}  # 第一条数据返回 True,其他数据返回 False
    {{ forloop.last }}  #  最后一条数据返回 True,其他数据返回 False
{% endfor %}
{% empty %}

可选的{% empty %}从句:在循环为空的时候执行

{% for i in listvar %}
    {{ forloop.counter0 }}
{% empty %}
    空空如也~
{% endfor %}
ifequal/ifnotequal标签

{% ifequal %}标签比较两个值,当它们相等时,显示在{% ifequal %}和{% endifequal %}之中所有的值。

{% ifequal user currentuser %}
    <h1>Welcome!</h1>
{% endifequal %}

和{% if %}类似,支持可选的{% else %}标签

{% ifequal section 'sitenews' %}
    <h1>Site News</h1>
{% else %}
    <h1>No News Here</h1>
{% endifequal %}
注释标签

注释使用{# #}

{# 这是一个注释 #}
include标签

{% include %}标签允许在模板中包含其他的模块的内容

{% include "nav.html" %}
csrf_token

csrf_token用于form表单中,作用是跨站请求伪造保护

如果不用该标签,在用form表单时,跳转页面会报403权限错误。

自定义标签和过滤器

1、在app目录下创建templatestags目录(目录名只能是templatestags)

2、在templatetags目录下创建任意py文件

3、在该py文件下

from django import template

register = template.Library()   # register的名字是固定的,不可改变

4、利用装饰器@register.filter自定义过滤器

注:装饰器的参数最多只能有2个

@register.filter
def my_filter(v1, v2):
    return v1 * v2

5、利用装饰器@register.simple_tag自定义标签

@register.simple_tag
def my_tag1(v1, v2, v3):
    return v1 * v2 * v3

6、在使用自定义标签和过滤器之前,要在html文件body的最上方导入该.py文件

{% load my_tags %}

7、在HTML中使用自定义过滤器

{{ 11|my_filter:22 }}

8、在HTML中使用自定义标签

{% my_tag1 11 22 33 %}

9、语义化标签

在该.py文件中导入mark_safe

from django.utils.safestring import mark_safe

在定义标签是,用上mark_safe方法,令标签语义化,相当于jQuery中的html()方法。

和前端HTML文件中的过滤器safe效果一样。

@register.simple_tag
def my_html(v1, v2):
    temp_html = "<input type='text' id='%s' class='%s' />" %(v1, v2)
    return mark_safe(temp_html)
配置静态文件

1、在项目根目录下创建statics目录

2、在settings文件的中配置添加以下配置

STATIC_URL = '/static/' # 别名 
STATICFILES_DIRS = [ 
    os.path.join(BASE_DIR, "statics"), 
]

3、在static目录下创建css目录,js目录,images目录,plugins目录,分别放css文件,js文件,图片,插件。

4、吧bootstrap框架放入插件目录plugins。

5、在HTML文件的head标签中引入bootstrap

注:此时引用路径中的要用配置文件中的别名static,而不是目录static。

在模板中使用需加入{% load static %}代码。

模板及成果

模板可以用继承的方式来实现复用,较少冗余内容

网页的头部和尾部内容一般都是一致的,就可以通过模板继承来实现复用。

父模板用于防止可重复利用的内容,子模版继承父模板的内容,并放置自己的内容。

  • 父模板

标签block…endblock(挖坑):父模板中的预留区域,该区域留给子模版填充差异性的内容,不同预留区域名字不能相同。

{% block 名称 %} 
预留给子模板的区域,可以设置设置默认内容
{% endblock 名称 %}
  • 子模版

子模版使用标签extends继承父模板

{% extends "父模板路径"%} 

子模版如果没有设置父模板预留区域的内容,则使用在父模板设置的默认内容,当然也可以都不设置,就为空。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值