zoukankan      html  css  js  c++  java
  • Flask框架 之模版

    一、过滤器

    safe:禁用转义;

      <p>{{ '<em>hello</em>' | safe }}</p>

    capitalize:把变量值的首字母转成大写,其余字母转小写;

      <p>{{ 'hello' | capitalize }}</p>

    lower:把值转成小写;

      <p>{{ 'HELLO' | lower }}</p>

    upper:把值转成大写;

      <p>{{ 'hello' | upper }}</p>

    title:把值中的每个单词的首字母都转成大写;

      <p>{{ 'hello' | title }}</p>

    trim:把值的首尾空格去掉;

      <p>{{ ' hello world ' | trim }}</p>

    reverse:字符串反转;

      <p>{{ 'olleh' | reverse }}</p>

    format:格式化输出;

      <p>{{ '%s is %d' | format('name',17) }}</p>

    striptags:渲染之前把值中所有的HTML标签都删掉;

      <p>{{ '<em>hello</em>' | striptags }}</p>

    first:取第一个元素

      <p>{{ [1,2,3,4,5,6] | first }}</p>

    last:取最后一个元素

      <p>{{ [1,2,3,4,5,6] | last }}</p>

    length:获取列表长度

      <p>{{ [1,2,3,4,5,6] | length }}</p>

    sum:列表求和

      <p>{{ [1,2,3,4,5,6] | sum }}</p>

    sort:列表排序

      <p>{{ [6,2,3,1,5,4] | sort }}</p>

    二、自定义过滤器

      1、定义函数方式

    @app.route("/")
    def index():
        data = [1,2,3,4,5]
        return render_template("index.html", data=data)
    
    # 1、定义过滤器
    def list(li):
        # 1,3,5
        return li[::2]
    # 2、注册过滤器
    # to_list是模板中使用的名字
    app.add_template_filter(list, "to_list")

      2、使用装饰器方式

    @app.template_filter("to_list")
    def list(li):
        # 1,3,5
        return li[::2]

    使用:{{data | to_list}}

    三、Flask-WTF表单扩展

    WTForms支持的HTML标准字段

    字段对象说明
    StringField 文本字段
    TextAreaField 多行文本字段
    PasswordField 密码文本字段
    HiddenField 隐藏文本字段
    DateField 文本字段,值为datetime.date格式
    DateTimeField 文本字段,值为datetime.datetime格式
    IntegerField 文本字段,值为整数
    DecimalField 文本字段,值为decimal.Decimal
    FloatField 文本字段,值为浮点数
    BooleanField 复选框,值为True和False
    RadioField 一组单选框
    SelectField 下拉列表
    SelectMultipleField 下拉列表,可选择多个值
    FileField 文本上传字段
    SubmitField 表单提交按钮
    FormField 把表单作为字段嵌入另一个表单
    FieldList 一组指定类型的字段

    WTForms常用验证函数

    验证函数说明
    DataRequired 确保字段中有数据
    EqualTo 比较两个字段的值,常用于比较两次密码输入
    Length 验证输入的字符串长度
    NumberRange 验证输入的值在数字范围内
    URL 验证URL
    AnyOf 验证输入值在可选列表中
    NoneOf 验证输入值不在可选列表中
    pip install flask-wtf
    from flask import Flask, redirect, request, url_for, render_template, session
    from flask_wtf import FlaskForm
    from wtforms import StringField, PasswordField, SubmitField
    from wtforms.validators import DataRequired, EqualTo
    
    # 创建flask应用对象
    # __name__ 代表当前模块名称
    # flask以当前目录为总目录,static目录为静态目录,templates为模版目录
    app = Flask(__name__)
    
    app.config["SECRET_KEY"] = "yang"
    
    # 定义表单模型类
    class RegisterForm(FlaskForm):
        # DataRequired 设置数据必填
        username = StringField(label=u"用户名:", validators=[DataRequired(u"请输入用户名")])
        password = PasswordField(label=u"密码", validators=[DataRequired("请输入密码")])
        password2 = PasswordField(label="确认密码", validators=[DataRequired("请输入秘密"), EqualTo("password", "两次密码不一致")])
        submit = SubmitField(label=u"注册")
    
    @app.route("/")
    def index():
        user_info = session.get("user_info")
        return str(user_info)
    
    @app.route("/register", methods=["POST", "GET"])
    def register():
        # 如果是post,会把前端返回的数据放到form中
        form = RegisterForm()
        # 验证表单数据是否合格
        if form.validate_on_submit():
            # 验证合格, 提取数据
            username = form.username.data
            password = form.password.data
            print("username: %s, password=%s" % (username, password))
            session["user_info"] = {"username": username, "password": password}
            return redirect(url_for("index"))
    
        return render_template("register.html", form = form)
    
    
    if __name__ == '__main__':
        # 启动应用程序
        app.run(port=8083,debug=True)
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <form action="" method="post">
        {{form.csrf_token}}
        {{form.username.label}}
        <p>{{form.username}}</p>
        {% for msg in form.username.errors %}
            <p>{{msg}}</p>
        {% endfor %}
    
        {{form.password.label}}
        <p>{{form.password}}</p>
        {% for msg in form.password.errors %}
            <p>{{msg}}</p>
        {% endfor %}
    
        {{form.password2.label}}
        <p>{{form.password2}}</p>
        {% for msg in form.password2.errors %}
            <p>{{msg}}</p>
        {% endfor %}
    
        {{form.submit}}
    
    </form>
    </body>
    </html>

     四、宏

    将重复的代码定义成宏。

    1、不带参数定义宏

    {% macro input() %}
      <input type="text"
             name="username"
             value=""
             size="30"/>
    {% endmacro %}
    
    {{ input() }}

    2、定义带参数的宏

    {% macro input(name,value='',type='text',size=20) %}
        <input type="{{ type }}"
               name="{{ name }}"
               value="{{ value }}"
               size="{{ size }}"/>
    {% endmacro %}
    
    {{ input(value='name',type='password',size=40)}}

    3、把宏单独抽取出来,封装成html文件,其它模板中导入使用

    文件名可以自定义macro.html

    {% macro function() %}
        <input type="text" name="username" placeholde="Username">
        <input type="password" name="password" placeholde="Password">
        <input type="submit">
    {% endmacro %}

    在其它模板文件中先导入,再调用

    {% import 'macro.html' as func %}
    {% func.function() %}

    五、模版的继承与包含

    extends 与 include

      

  • 相关阅读:
    Linux rm命令详解
    标准时间格式("%Y-%m-%dT%H:%M:%S")转化(基于python 3.6)
    通过load json文件读取json指定数据(基于python 3.6)
    遍历win10文件夹并解析json文件,按照json格式存入mongo数据库(基于python 3.6)
    mongo的备份数据库导入现有数据库
    python 获取网页内容新增网页分类+删除指定后缀数组元素功能(基于python 3.6)
    sqlite3的安装和使用(基于python3.5)
    python 获取提交表单网址内容(即需要密码网址)以财务网站为例
    python 分析PDF文件 (基于使用pdf2htmlEX.exe python3.6)
    python 复制多个文件到指定目录(基于python 3.X)
  • 原文地址:https://www.cnblogs.com/yang-2018/p/11020041.html
Copyright © 2011-2022 走看看