django基础,django框架菜鸟教程

  公文

  普通语法只需要记住两个特殊符号:

  {{}}和{%%}

  使用{{}}表示变量,使用{%%}表示逻辑。

  变量{ {变量名}}

  变量名由字母数字字符和下划线组成。

  圆点(。)在模板语言中有特殊的含义,用来获取对象对应的属性值。

  几个例子:

  视图中的代码:

  定义模板_测试(请求):

  l=[11,22,33]

  d={name: alex}

  类别人员(对象):

  def __init__(自己,姓名,年龄):

  self.name=name

  年龄=年龄

  定义梦想(自我):

  return { is dream . 。格式(自我名称)

  亚历克斯=人(姓名=亚历克斯,年龄=34岁)

  Egon=Person(name=Egon ,age=9000)

  伊娃_J=人(姓名=伊娃_J ,年龄=18岁)

  person_list=[Alex,Egon,Eva_J]

  返回render(request, template_test.html ,{l: l, d: d, person_list: person_list})

  模板中支持的书写:

  {#取L #}中的第一个参数

  {{ l.0 }}

  {#取字典中键的值#}

  {{ d.name }}

  {#获取对象的名称属性#}

  {{ person_list.0.name }}

  {#.操作只能调用不带参数的方法#}。

  {{ person_list.0.dream }}

  过滤器语法:{{值过滤器名称:参数}}

  系统默认值

  {{ valuedefault: nothing}}如果未传递值,则不显示任何内容。

  长度

  {{ valuelength }}

  “”周围没有空格没有空格没有空格

  返回值的长度,比如value=[a , b , c , d],会显示4。

  文件大小格式

  将该值格式化为“人类可读”的文件大小(例如,“13 KB”、“4.1 MB”、“102字节”等)。).例如:

  {{ valuefilesizeformat }}如果值为123456789,则输出将为117.7 MB。

  薄片

  切片

  { { value slice: 2:-1 } }日期

  格式化

  { { value date: Y-m-d H:I:s } }安全

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

  例如:

   Value= a href=# 单击我/a

  {{ valuesafe}}truncatechars如果字符串超过指定的字符数,它将被截断。的截断字符串将以可翻译的省略号序列(“.”)结束).

  参数:截断字符的数量

  {{ valuetruncatechars:9}}自定义过滤器自定义过滤器只是一个带有一个或两个参数的Python函数:

  变量(input)的值(不一定是字符串参数的值)可以有默认值,也可以完全省略。比如在filter {{var foo: "bar"}}中,filter foo会传递变量var和参数“bar”。

  用户定义的过滤器代码文件放置位置:

  app01/

  __init__。巴拉圭

  models.py

  Templatetags/#在app01下新建一个包包。

  __init__。巴拉圭

  App01_filter.py #构建一个文件来存储自定义过滤器

  views.py

  编写自定义过滤器

  从django导入模板

  注册=模板。库()

  @register.filter(name=cut )

  定义切割(值,参数):

  返回值. replace(arg,)

  @register.filter(name=addSB )

  def add_sb(值):

  返回“{ SB }”。格式(值)

  使用自定义过滤器

  {#首先导入我们的自定义过滤器文件#}

  {% load app01_filters %}

  {#使用我们的自定义过滤器#}

  {{ somevariablecut:0 }}

  {{ d.nameaddSB }}

  Tagsfor

  保险商实验所

  用户列表%}中用户的{%

  li {{ user.name }} /li

  {% endfor %}

  /ul for循环的一些可用参数:

  可变的

  描述

  forloop .柜台

  当前循环的索引值(从1开始)

  forloop.counter0

  当前循环的索引值(从0开始)

  forloop.revcounter

  当前循环的反向索引值(从1开始)

  forloop.revcounter0

  当前循环的反向索引值(从0开始)

  forloop.first

  当前循环是否是第一个循环(布尔值)

  forloop.last

  当前循环是不是最后一次循环(布尔值)

  forloop.parentloop

  本层循环的外层循环

  为.空的

  保险商实验所

  用户列表%}中用户的{%

  li {{ user.name }} /li

  {% empty %}

  里空空如也/李

  {% endfor %}

  /ul

  如果,埃利夫和否则

  {% if user_list %}

  用户人数:{{用户列表长度}}

  {% elif黑名单%}

  黑名单数:{{黑名单长度}}

  {% else %}

  没有用户

  {% endif %}

  当然也可以只有如果和其他

  {% if user_listlength 5 %}

  七座豪华运动型多功能车

  {% else %}

  黄包车

  {% endif %}if语句支持and、or 、==、or!=、=、=、in、not in、is、is not判断。

  随着

  定义一个中间变量

  { % total=business。员工。计数% }

  {{总计}}员工{ {总计复数}}

  {% endwith %}csrf_token这个标签用于跨站请求伪造保护。

  在页面的形式表单里面写上{% csrf_token %}

  注释{# .#}注意事项1.姜戈的模板语言不支持连续判断,即不支持以下写法:

  {% if a b c %}

  .

  {% endif %}

  2.姜戈的模板语言中属性的优先级大于方法

  定义xx(请求):

  d={a: 1, b: 2, c: 3, items: 100}

  return render(请求, xx.html ,{ 数据:d})如上,我们在使用提出方法渲染一个页面的时候,传的字典d有一个键是项目并且还有默认的d。项目()方法,此时在模板语言中:

  {{ data.items }}默认会取d的项目键的值。

  母板

  !声明文档类型

  html lang=en

  头

  meta charset=UTF-8

  meta http-equiv= x-ua-compatible content= IE=edge

  meta name= viewport content= width=device-width,initial-scale=1

  标题标题/标题

  {% block page-css %}

  {% endblock %}

  /头

  身体

  氕这是母板的标题/h1

  {% block page-main %}

  {% endblock %}

  氕母板底部内容/h1

  {% block page-js %}

  {% endblock %}

  /body

  /html

  注意:我们通常会在母板中定义页面专用的半铸钢钢性铸铁(铸造半钢)块和射流研究…块,方便子页面替换。

  继承母板在子页面中在页面最上方使用下面的语法来继承母板。

  {% extends layouts.html %}块(区块)通过在母板中使用{% block xxx %}来定义块。

  在子页面中通过定义母板中的街区名来对应替换母板中相应的内容。

  {% block page-main %}

  p世情薄/p

  p人情恶/p

  p雨送黄昏花易落/p

  {% endblock %}组件可以将常用的页面内容如导航条,页尾信息等组件保存在单独的文件中,然后在需要使用的地方按如下语法导入即可。

  {% include navbar.html %}静态文件相关{% load static %}

  img src= { % static images/Hi。jpg“% }”alt=嗨!/引用射流研究…文件时使用:

  {% load static %}

  脚本src= { % static mytest。js“% }”/脚本某个文件多处被用到可以存为一个变量

  {% load static %}

  { % static images/hi。jpg 作为我的照片% }

  img src={{我的照片}} /img使用get _ static _ prefix { % load static % }

  img src= { % get _ static _ prefix % } images/Hi。jpg alt=嗨!/或者

  {% load static %}

  { % get _ STATIC _ PREFIX as STATIC _ PREFIX % }

  img src= { { STATIC _ PREFIX } } images/Hi。jpg alt=嗨!/

  img src= { { STATIC _ PREFIX } } images/hi2。jpg alt=你好!/自定义标签和自定义过滤器类似,只不过接收更灵活的参数。

  定义注册简单标签

  @注册。简单标记(name= plus )

  def plus(a、b、c):

  返回"{} {} {}"。格式(甲、乙、丙)使用自定义简单标签

  {% load app01_demo %}

  {#简单标签#}

  { % plus 1 2 abc % }包含标记多用于返回超文本标记语言代码片段

  示例:

  templatetags/my_inclusion.py

  从框架导入模板

  注册=模板。库()

  @注册。inclusion _ tag(结果。html’)

  定义显示结果(n):

  n=1 if n 1 else int(n)

  数据=[第{}项。范围(1,^北部1)中我的格式]

  返回{data: data}

  模板/片段/结果。超文本标记语言

  保险商实验所

  {% for choice in data %}

  李{ { choice } }/李

  {% endfor %}

  /ul模板/索引. html

  !声明文档类型

  html lang=en

  头

  meta charset=UTF-8

  meta http-equiv= x-ua-compatible content= IE=edge

  meta name= viewport content= width=device-width,initial-scale=1

  标题包含_标签测试/标题

  /头

  身体

  {% load inclusion_tag_test %}

  {% show_results 10 %}

  /body

  /html