Django:MTV——模版语句

1.Django框架介绍

1.1MVC框架(Model View Controller)

​ 全名是Model View Controller ,是软件工程中的一种软件架构模式,把软件分为三个基本部分:模型(Model)、视图(View)和控制器(Controller),具有耦合性低,重用性高,声明周期成本低等优点。

  • M:model模型

  • V:view视图-HTML

  • C:controller 控制器 ---路由传递指令 业务逻辑

最上层 是视图层(veiw)面向用户,它提供用户操作界面

中间一层 是控制层(Controller),负责根据用户从视图层输入指令,选取"数据层"中的数据,然后对其进行相应的操作,得到结果

最底层 数据层(Models)程序操作的数据或信息

这三层紧密联系,但互相独立,每一层内部变化不影响其它层,每一层都有对外提供接口,供上面一层调用。

1.2Django中的MTV(Model Template View)

M:Model 模型ORM:负责业务对象与数据库的对象

T:Template 模版-HTML:负责如何把页面展示给用户

V:View 业务逻辑:负责业务逻辑,并在适当时候调用Model 和Template

此外:Django还有urls分发器,负责将URL页面请求奋发给不同views处理,views在调用相应Model和Template

1.3string_if_invalid 设置

  • 在settings.py 文件下设置如下图

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',
            ],
            "string_if_invalid":"变量不存在",
        },
    },
]
  • 应用:只作调试用途!当遇到一个不存在的变量时,许多模板,包括Admin站点中的模板,都依赖于模板系统的默认。如果您设置string_if_invalid ,则当变量不存在就会显示你设置的值。而不是''。而default筛选器以显示提供的默认值,而不是无效的字符串。

  • HTML显示效果

2.Django常见命令

2.0 注释:

{#这是注释#}
  • Django模版中特殊符号

    {{ }}  表示变量,在模版替换成值
    
    {% %}  表示逻辑相关的操作
    
    

2.1变量

  • 格式:{{变量名}}
  • 变量名由字母数字和下划线组成
  • 点(.)在模版语言中有特殊的含义,可以获取相应属性值
#views.py
from django.shortcuts import render
from app01 import model
class Person:
    def __init__(self,name,age):
        self.name = name
        self.age = age
    def talk(self):
        return "咱也不知道,咱也不敢问!"

    def __str__(self):
        return "Person obj:{}-{}".format(self.name,self.age)

def test(request):
    lst = [11,22,33]
    dic = {"name":"xjk","age":22}
    obj = Person("曹操",55)


    return render(request,"test.html",{"lst":lst,"dic":dic,"obj":obj})
#test.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <p>{{ lst.0 }}</p>
    <p>{{ dic.name }}</p>
    <p>{{ obj.name }}</p>
    <p>{{ obj.talk }}</p>
</body>
</html>
#结果
11  #列表索引0的数
xjk #获取字典name键的值
曹操 #获取对象的name值
咱也不知道,咱也不敢问!  #对象talk的方法
  • 需要注意:当模版系统遇到一个(.)时,会按照如下的顺序去查询:
    • 在字典中查询
    • 属性或方法
    • 数字索引

2.2 Filters过滤器

  • 修改变量的显示结果
  • 语法:{{value|filter_name:参数}} 注意 “:” 左右没有空格
1 default
  • 如果value值没有传,就显示"什么都没有".
{{ value|default:"什么都没有" }}
2 filesizeformat
  • 将值格式化为一个人类可读文件尺寸(例如"13KB","4.1MB","102bytes"等等)
{{ 234344|filesizeformat }}

3 add
  • 给变量加参数
如果变量时数字?
当value = "125" 为字符串
{{value|add:"2"}}
输出结果:127

当vlaue = 125 为数字
{{value|add:"2"}}
输出结果:127

{{list1|add:list2}}
当list1 与list2是列表,那么输出当list1和list2相加,一个新的列表,
  • add传入2个参数,如果一个参数为字符串字母一个为数字,则无法做拼接或累加
4 lower
  • 小写
{{ value|lower }}
5 upper
  • 大写
{{ value|upper}}
6 title
  • 标题
{{ value|title }}
7 ljust
  • 左对齐
"{{ value|ljust:"10" }}"
8 rjust
  • 右对齐
"{{ value|rjust:"10" }}"
9 center
  • 居中
"{{ value|center:"15" }}"

10 length
  • 长度,可以是字符串,可以是列表
{{value|length}}
11 slice
  • 切片
{{ value|slice:"2:-1"}}
{{ value|slice:"-2:1:-1"}}
12 first
  • 取第一个元素
{{ value|first }}
13 last
  • 取最后一个元素
{{ value|last }}
14 join
  • 使用字符串拼接列表,同python中str.join(list)
{{ value|join:" // " }}



15 truncatechars
  • 如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。
views.py
value = "hello python"

test.html
{{ value|truncatechars:5 }}

显示结果:he...
#表示如果字符串长度超过5个长度,就只显示5个。
显示5个字符里,包括了三个点。

16 truncatewords
  • 如果英文单词字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。
views.py
value = "hello my name is Lilei what's yor name"

test.html
{{ value|truncatewords:5 }}

显示结果:hello my name is Lilei ...
17 safe
  • Django的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,比如我们做一个内容管理系统,后台添加的文章中是经过修饰的,这些修饰可能是通过一个类似于FCKeditor编辑加注了HTML修饰符的文本,如果自动转义的话显示的就是保护HTML标签的源文件。为了在Django中关闭HTML的自动转义有两种方式,如果是一个单独的变量我们可以通过过滤器“|safe”的方式告诉Django这段代码是安全的不必转义。
{{value|safe}}
  • 示例:views.py
{#views.py#}
def test(request):
	 value = '<a href="https://www.baidu.com/">百度</a>'
	  return render(request,"test.html",{"value":value}


{#test.html#}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <div>{{ value }}</div>
    <div>{{ value|safe }}</div>
</body>
</html>
  • 输入结果如下:
18 date
  • 日期格式化
  • 若要显示
{#views.py#}
import datetime
now = datetime.datetime.now()

{#test.html#}
<div>{{ now|date:"Y-m-d H:i:s" }}</div>

  • 显示效果

如果有用多个时间写多个{{ now|date:"Y-m-d H:i:s" }},这样会代码冗余变长,可以通过配置setting.py文件内容

USE_L10N = False
DATETIME_FORMAT="Y-m-d H:i:s"
DATETIME_FORMAT = "Y年m月d日 H时i分s秒"
  • 此时在views中可以{{now}} 直接调用

2.3 自定义filter

1.在app下创建一个名为templatetags的包(必须)

2.在python中创建py文件,文件名自定义,要求为.py

3.在py文件中写:

from django import template
register = template.Library()   #register也不能变

4.写函数 + 装饰器

@register.filter
def add_xx(value,arg):
	return "{}-{}".format(value,arg)

5.html使用自定义函数

{% load py文件%}}
{{ "mjj"|add_xx:"haha"}}

注意:自定义filter,可以这么设置@register.filter(is_safe=True) 保护

  • 示例

解题:

  • 若想对自定义函数更名,当然调用时候也要更名

原文地址:https://www.cnblogs.com/xujunkai/p/11846954.html