Flask入门教程——李辉 第三章 关键知识梳理

文章目录

Flask入门教程------李辉 第三章 关键知识梳理

两个概念
  • 模板
  • 渲染

把包含变量和运算逻辑的HTML或其他格式的文本叫做模板 ,执行这些变量替换和逻辑计算工作的过程被称为渲染

Flask使用的模板渲染引擎是Jinja2

render_template函数用于渲染模板

模板(Jinja2)基本语法
  • 三种常用定届符
  • 过滤器语法 {``{变量|过滤器}}
  1. 标记变量 {``{ ... }}
  2. 标记语句 {% ... %}
  3. 写注释 {# ... #}

所有可用的过滤器

实现案例
  1. 创建模板文件夹
bash 复制代码
mkdir templates
  1. 编写主页模板(templates/index.html)

vscode快速生成网页模板技巧

vscode Jinja2扩展 Jinja2 Enhance

bash 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>{{ name }}'s Watchlist</title>
</head>
<body>
    <h2>{{ name }}'s Watchlist</h2>
    {# 使用 length 过滤器获取 movies 变量的长度 #}
    <ul>
        {% for movie in movies %} {# 迭代movies 变量 #}
        <li>
            {{ movie.title }} - {{ movie.year }}
            {# 等同于 movie['title'] #}
            {% endfor %} {# 不要忘记endfor 来结束for语句 #}
        </li>
    </ul>
    <footer>
        <small>
            &copy; 2018 <a href="http://helloflask.com/tutorial">HelloFlask</a>
        </small>
    </footer>
</body>
</html>
  1. 创建虚拟数据
py 复制代码
# coding = utf-8
from faker import Faker

fake = Faker(locale="zh_CN")

def create_movies_generator(number:int):
    """创建生成器
    :param number: 生成的个数整数
    :return: 字典类型的数据
    """
    for _ in range(number):
        title = fake.sentence()
        year = fake.year()
        yield {"title": title,"year":year}

if __name__ == "__main__":
    movies = list(create_movies_generator(10))

    print(movies)
  1. 渲染主页
py 复制代码
# coding = utf-8
from flask import Flask,render_template


app = Flask(__name__)

name = "开心开心-急了"
movies = [
            {'title': '实现研究而且.', 'year': '1997'}, 
            {'title': '重要出来不要不要广告.', 'year': '1987'},
            {'title': '活动这些城市.', 'year': '1995'},
            {'title': '历史网上你的来源选择销售没有.', 'year': '2006'},
            {'title': '这样简介个人如果信息怎么类型.', 'year': '2024'}, 
            {'title': '能够时候两个.', 'year': '2004'}, 
            {'title': '部分有限电影不要得到应用.', 'year': '2022'}, 
            {'title': '设备处理最后大学为了.', 'year': '1996'},
            {'title': '来自谢谢决定.', 'year': '2021'},
            {'title': '提供所以大家您的非常以后有关.', 'year': '2016'}
        ]

@app.route("/")
def index():
    return render_template("index.html",name=name,movies=movies)
效果演示
相关推荐
爱喝可乐的老王3 分钟前
PyTorch简介与安装
人工智能·pytorch·python
看我干嘛!7 分钟前
第三次python作业
服务器·数据库·python
deephub8 分钟前
用 PyTorch 实现 LLM-JEPA:不预测 token,预测嵌入
人工智能·pytorch·python·深度学习·大语言模型
好好研究24 分钟前
Spring Boot - Thymeleaf模板引擎
java·spring boot·后端·thymeleaf
爬山算法26 分钟前
Hibernate(76)如何在混合持久化环境中使用Hibernate?
java·后端·hibernate
我的xiaodoujiao32 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 44--将自动化测试结果自动推送至钉钉工作群聊
前端·python·测试工具·ui·pytest
她说..32 分钟前
策略模式+工厂模式实现单接口适配多审核节点
java·spring boot·后端·spring·简单工厂模式·策略模式
沈浩(种子思维作者)32 分钟前
铁的居里点(770度就不被磁铁吸了)道理是什么?能不能精确计算出来?
人工智能·python·flask·量子计算
Andy Dennis34 分钟前
FTP局域网功能小网站V2_2
服务器·flask·html5
yufuu9834 分钟前
使用Scikit-learn进行机器学习模型评估
jvm·数据库·python