zoukankan      html  css  js  c++  java
  • 模板1

    模板知识点

    jinja2模板中有自带的过滤器,有需要直接拿来使用。也可以自己定义过滤器

    在过滤器中,有一些常见得操作及关键字。有对字符串的操作,还有对大小写转换的操作。还有对list的操作
    过滤器的语法
    {# 过滤器调用方式 {{ 变量 | 过滤器的名称 }} #} 这里用到了注释模板中的注释

    首先整理一下关键字
    字符串:
    1.对大写转换为小写,lower。相对的,那么就有小写转换为大写,upper。
    那么还有是首字符大写,captialize,这个单词在字符串的操作中出现过
    2.还有一个转义。如果在输出中出现了html标签,那么在输出的时候我又不想显示标签,我只想要标签给我达到的效果,
    而不需要看到标签的出现,就需要转义
    比如:
    safe过滤器,可以禁用转义
    {{ '<strong>hello</strong>' | safe }}
    我们这里用到了safe的关键字。hello就会在输出的时候变为粗体
    在这里要提到另一个过滤器的关键字。striptage
    比如:
    过滤所有的html标签,em标签是斜体。跟转义没有任何关系,只是在过滤标签,把所有文本中的标签过滤掉
    {{ '<em>hello</em>' | striptags }}
    放在这里是要对禁止转义有个区别,safe是实现标签的功能,不输出标签,striptage是把标签过滤掉,只输出文本

    3.字符串反转用到reverse
    {{ '来一个反转' | reverse }}

    list的相关过滤及关键字:
    1.我们可以拿到列表中的首个元素,first
    {{ [100,99,65] | first }}
    2.相对的,我们就可以拿到末尾的元素 last
    {{ [100,90,520] | last }}
    3.我们也可以对list量取长度。length
    {{ [1,2] | length }}
    4.如果list中的元素都为int。也可以求和 sum
    {{ [100,200] | sum }}
    5.list中的int杂乱无序,也可以将list排序 sort
    {{ [12,3,4,56,7,89,8,76,5] | sort }}

    以上的都是对单个的来说,那么对于语句块来说也可以使用,对英文都转换为小写,或者大写都可以
    {% filter upper %}
    hello world hello python hello flask hello jinja2 hello myself hello my broter
    {% endfilter upper %}
    需要注意的是,要有结束

    既然单个的使用过滤器,我们是不是也可以一起配合使用,是的,就会有链式过滤,也就是嵌套过滤,需要注意的是执行顺序
    链式调用(嵌套的使用过滤器)
    {{'abcdefg' | reverse | upper }} 双管道调用,先反转。后大写
    {{'abcdefg' | upper | reverse }} 执行的顺序。谁先谁后要取决先调用了哪个关键字


    jinja2模板给我们有很多的过滤器选择,但是我们也可以自己定义过滤器,首先需要在py文件中配置
    所需要的过滤器。一切代码都是为了业务,代码也是实现业务的需求
    需要注意的是在函数中我们要带有参数,这个参数类似于jquery中的filter所需要带的参数

    # 自定义一个过滤器
    def my_filter(val):
    return '$' + str(val)
    # 把自定义的过滤器赋给模板,第一个参数是自定义的过滤器的名称,第二个是过滤器的名称
    # 这里调用 add_template_filter 这个方法。来对方法名进行传递。
    app.add_template_filter(my_filter, 'my_filter')


    对于flask中的宏编程。我们使用 macro 来对宏起个名称
    宏编程 对于我们来说是减少了代码的重用。以及简化了标签的操作,对与开发效率有很大的提升,
    在html中。相信大多数都用到了。input ul li div 这些常用的标签。那么我们在模板套用中,就可以定义一次
    所需要的标签。在之后的输出中,直接调用
    比如:
    减少重复的操作,定义一个宏
    {% macro input(value,type,id) %} 也可用简写的变量来代表 input 将其替换为 i 也是可以的
    为了只管显示,暂时不替换, 我们使用了但括弧。证明我们写的是逻辑。
    <input style="300px;" id="{{ id }}" type="{{ type }}" value="{{ value }}" />
    {% endmacro %}
    <br />

    调用宏 传参的时候要和上边的参数要等同,不然会报错,
    {{ input(type='text',value='用户名',id="abc") }}
    <!-- 上边的宏等同于这里的普通html标签<input type="text" value="用户名" id="abc">,很方便,很实用 -->
    <br />
    {{ input(type='button',value='按钮',id="abc") }}
    <br />
    {{ input(type='password',value='密码', id="abc") }}


    那么为了方便使用重复的页面,我们也可以使用继承模板。还有包含模板,一般使用包含,俩个都好理解,用法不同
    我们访问页面的时候在最上边会有导航的信息。也就是要跳转到哪。实现路由的访问,那么每一页中我们为了统一效果
    是不是就可以将之前的页面样式拿来使用。这就涉及到了继承,以及包含。
    在继承的时候,会使用 block 关键字。记住,想要现实效果,别忘了在Py文件中导入数据,引入页面,
    那么就有了被继承的概念。谁继承谁。又是谁被谁继承,所以还有个关键字,就是extends

    {# 模板继承使用block关键字 #}

    {% block top %}

    这里是导航栏,也是一样,导航栏的样式设置基本都一样,不然整体效果就不是很好,要有整体性

    {% endblock top %}
    <br />

    {% block content %}

    需要被继承的内容,在这里填充
    下边的所有内容在另一个页面,需要继承过来,继承过来的只是内容,
    面向对象中继承父类的同名方法,就是说,只是调用了东西。而没有做这个页面的修改,正好相反
    就可以吧另一个页面写的内容拿到这里使用

    {% endblock content %}

    {# 继承模板使用关键字extends #}

    {% extends 'day03_base.html' %}

    {% block content %}
    son 和 base 是一对儿。 top 和 body 是一对儿。

    那么这里的就是导航栏下边的所有的内容,就是说继承的所有机制<br />
    为了提高开发效率。将一个主要的模板。相同的组件都可以继承,与之相反的是包含机制。<br />
    包含的机制比这个好理解。也更好用

    {% endblock content %}

    那么包含也是类似。只是没有继承这样麻烦。也是讲原有设计好的模板直接拿过来使用。也就是说可以分开使用,
    类似于拼接起来的模型。这只是我的理解。将一个个组件接起来使用,构建成一个完整的动态页面

    {# 使用include关键字,来包含之前定义好的模板 #}
    <!-- 调用了另一个文件 -->
    {% include 'day03_top.html' %}

  • 相关阅读:
    模拟ORA-26040: Data block was loaded using the NOLOGGING option
    poj 2752 Seek the Name, Seek the Fame (KMP纯模版)
    一入python深似海--变量和对象
    Codeforces 448 C. Painting Fence
    Unix网络编程 高级IO套接字设置超时
    [ JavaScript ] JavaScript 实现继承.
    讲座:与迷茫为友的成长
    分享:进化版动漫更新提醒(微信及软件)
    设计模式------模板方法模式
    BasePath问题-nginx负载均衡配置
  • 原文地址:https://www.cnblogs.com/LeYu/p/10159988.html
Copyright © 2011-2022 走看看