热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

教你使用模板引擎和表单插件的实例详解(python)

后端开发|Python教程模板引擎,表单插件,python后端开发-Python教程经过了第一章的内容,已经可以做出一些简单的页面,首先用这种方式做一个登录页面,首先要创建一个lo

后端开发|Python教程教你使用模板引擎和表单插件的实例详解(python)
模板引擎,表单插件,python
后端开发-Python教程
经过了第一章的内容,已经可以做出一些简单的页面,首先用这种方式做一个登录页面,首先要创建一个login的路由方法:
网站源码的数据库,vscode图标变成白色,uefi下装ubuntu,tomcat高于jdk,sqlite单句柄多线程,从零开始编写一个微前端框架,云南爬虫技术费用是多少,php微信转发,域名适合哪种seo,金融网站模板素材,网页传奇私服发布网站源码,服装模板 手机lzw

@app.route("/login",methods=["GET"])def login(): html="" \ "

" \ "" \ "" \ "" \ "
请输入用户名
请输入密码
" \ "" return html

这个页面返回后是一个简单的登录页,显示结果如下:

androidsqlite源码下载,vscode 远程文件夹,ubuntu 剪切视频,设置tomcat内存溢出,bilibili 反爬虫,php舍去小数,seo效果推广代理秒收录,网站免费制作代码,wordpress淘宝客自适应模板lzw
教你使用模板引擎和表单插件的实例详解(python)
java服务端源码,vscode ruby插件,ubuntu酷炫桌面,alpha tomcat,c sqlite 配置,建一个小型的购物网站服务器一年要多少钱,php 签收 插件,onsenui前端框架四,hispider 爬虫,php项目开发实战入门,seo有哪些软件,html5新闻网站模板,网页 按钮素材,最简单网页模板中文,php页面跳转源码,宠物管理系统源码,j2ee程序代码lzw
然后是一个登录的post返回页:

@app.route("/login",methods=["POST"])def loginPost(): username=request.form.get("username","") password=request.form.get("password","") if username=="test" and password=="123" : return "登录成功" else: return "登录失败"

输入test和123后,显示登录成功

教你使用模板引擎和表单插件的实例详解(python)

功能上当然是实现了,但是从其他方面来说,却很难说它是一个能够实际应用的程序,即使不考虑js脚本和css样式表,就从简简单单的维护来说,就是一场噩梦,比如说像增加一个验证码框,我想不会有人认为这是一件愉快的工作。

所以,首先来说,我们要把页面html部分独立出来,这点,flask提供了jinja2模板引擎来实现。

jinja2模板引擎同样符合flask最基础的约定,即众多配置中都有一个基础的默认值,相对jinja2来说,有一个最重要的默认值,即模板文件放在templates文件夹,这个文件夹虽然可以自定义,但目前来说,使用默认值已经足够了。

好,首先在PyCharm的项目根目录创建templates文件夹,然后在文件夹内创建login.html文件,当然目录结构如下:

教你使用模板引擎和表单插件的实例详解(python)

在login.html中输入代码如下:

请输入用户名
请输入密码

代码很简单,也名没有进行样式方面的美化,其实目前就我来说,仅仅是因为有了智能感知,就有足够的理由使用模板了,然后,对default.py的login方法进行修改代码为:

from flask import render_template #头部,引入模板渲染方法@app.route("/login",methods=["GET"])def login(): return render_template("/login.html") #渲染模板,默认找templates文件夹下的login.html文件

由于html模板内的代码和直接直接写在py文件中的一样,所以此时刷新页面,显示效果和刚刚相同,虽然显示效果没有明显的改观,但此时如果修改html中的某一元素,则会方便很多。

关于jinja2模板引擎还支持一些更强大的功能,比如使用index做一些说明:

基本用法

修改default.py中的部分代码为:

from flask import render_template #页头,导入渲染函数@app.route("/")def index(): return render_template("index.html",site_name='myblog')

index.html中的代码为:

这个站点的名字为 {{site_name}}

flask的render_template函数支持多参数,其中函数的第一个参数为模板名,之后可以提供若干参数,均为键值对,为模板中的变量提供数据。如此例子中,为site_name提供了myblog的值,而模板内使用{{参数名}}来表示一个变量

此时浏览器输入地址输出结果为:

这个站点的名字为 myblog

jinja2模板还提供了一些变量过滤器,如代码:

这个站点的名字为 {{site_name}}

这时输出为:

这个站点的名字为 myblog

常用过滤器如下

safe 不转义
capitalize 首字母大写
lower 转换为小写
upper 转换为大写
trim 去收尾空格
striptages 去除html标签

除此之外,Jinja2的变量还可以是一些复杂类型,甚至可以使用一些复杂类型的常用方法,如:

这个站点的名字为 {{site_name}}

这时输出为:

这个站点的名字为 myblog

控制语句

控制语句是一个模板的基本功能,同样的jinja2也提供了相应的功能:

//选择{% if name=='test' %} 这是测试{% else %} {{name}},你好{% endif %}//循环

    {% for blog in blogs%} {{ blog.title }} {% endfor%}

除了这些基本用法,模板还为一些代码的重复使用提供了宏的功能,如将如下代码写入macros.html文件中

{% macro render_title(blog)%}

  • {{blog.title}}
  • {% endmacro%}

    然后在之前的模板中:

    {% import 'macros.html' as macros %}

      {% for blog in blogs %} {{ macros.render_title(blog) }} {% endfor %}

    执行结果与之前的完全相同

    Jinja2还提供了一个更为强大的功能,即模板继承,这个个人感觉有点像java的sitemesh框架,它首先需要创建一个base.html的基模板:

    {% block head %} {% endblock %} {% block body %} {% endblock %}

    其中block标签的意思表示在子模板中可以修改,具体到此例子,则可修改的部分为 head,title,body。下面为子模板代码:

    {% extends "base.html" %}{% block title %}{{site_name[2:]}}{% endblock %}{% block head %} {{super()}}{% endblock %}{% block body %} 这个站点的名字为 {{site_name}} {% endblock %}

    此时执行结果仍为:

    这个站点的名字为 myblog

    现在有了模板引擎,不管怎么说,仅仅就页面层来说,已经可以很轻松的做出一些不错的功能了,但很明显,现在的界面还不是很美观,下一章将把现在主流的前端框架bootstrap与flask框架进行整合。


    推荐阅读
    • 全面解析JavaScript代码注释技巧与标准规范
      在Web前端开发中,JavaScript代码的可读性和维护性至关重要。本文将详细介绍如何有效地使用注释来提高代码的可读性,并探讨JavaScript代码注释的最佳实践和标准规范。通过合理的注释,开发者可以更好地理解和维护复杂的代码逻辑,提升团队协作效率。 ... [详细]
    • 深入解析HTML5字符集属性:charset与defaultCharset
      本文将详细介绍HTML5中新增的字符集属性charset和defaultCharset,帮助开发者更好地理解和应用这些属性,以确保网页在不同环境下的正确显示。 ... [详细]
    • HTML中span元素为何会脱离li元素对齐?
      在HTML布局中,有时会遇到span元素未能与li元素保持对齐的问题。本文将探讨这一现象的原因,并提供解决方案。 ... [详细]
    • C盘无法格式化的原因及解决方法
      本文探讨了C盘无法格式化的原因,并提供了详细的解决方案,帮助用户顺利进行系统维护。 ... [详细]
    • CSS3 @font-face 字体应用技术解析与实践
      在Web前端开发中,HTML教程和CSS3的结合使得网页设计更加多样化。长期以来,Web设计师受限于“web-safe”字体的选择。然而,CSS3中的`@font-face`规则允许从服务器端加载自定义字体,极大地丰富了网页的视觉效果。通过这一技术,设计师可以自由选择和使用各种字体,提升用户体验和页面美观度。本文将深入解析`@font-face`的实现原理,并提供实际应用案例,帮助开发者更好地掌握这一强大工具。 ... [详细]
    • 在《天天酷跑》中,腾讯微信宠物的升级技巧和策略对于提升游戏体验至关重要。本文详细解析了如何通过合理分配经验和资源,快速提升宠物等级,以及如何选择合适的宠物搭配,以增强角色的综合能力。此外,还介绍了游戏中的一些隐藏机制和优化建议,帮助玩家更好地利用微信宠物的优势,提高游戏成绩。 ... [详细]
    • 帝国CMS中的信息归档功能详解及其重要性
      本文详细解析了帝国CMS中的信息归档功能,并探讨了其在内容管理中的重要性。通过归档功能,用户可以有效地管理和组织大量内容,提高网站的运行效率和用户体验。此外,文章还介绍了如何利用该功能进行数据备份和恢复,确保网站数据的安全性和完整性。 ... [详细]
    • FreeBSD环境下PHP GD库安装问题的详细解决方案
      在 FreeBSD 环境下,安装 PHP GD 库时可能会遇到一些常见的问题。本文详细介绍了从配置到编译的完整步骤,包括解决依赖关系、配置选项以及常见错误的处理方法。通过这些详细的指导,开发者可以顺利地在 FreeBSD 上完成 PHP GD 库的安装,确保其正常运行。此外,本文还提供了一些优化建议,帮助提高安装过程的效率和稳定性。 ... [详细]
    • 本文深入探讨了Java多线程环境下的同步机制及其应用,重点介绍了`synchronized`关键字的使用方法和原理。`synchronized`关键字主要用于确保多个线程在访问共享资源时的互斥性和原子性。通过具体示例,如在一个类中使用`synchronized`修饰方法,展示了如何实现线程安全的代码块。此外,文章还讨论了`ReentrantLock`等其他同步工具的优缺点,并提供了实际应用场景中的最佳实践。 ... [详细]
    • 优化后的标题:利用 jQuery 实现高效树形结构元素选择与操作
      在Web前端开发中,DOM结构本质上是一种树形结构。通过优化后的jQuery选择器,可以高效地选择和操作DOM树中的节点。这些选择器不仅简化了代码编写,还提高了性能和可维护性。本文将详细介绍如何利用jQuery的树形选择器实现高效的元素选择与操作。 ... [详细]
    • Python 数据可视化实战指南
      本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
    • MySQL 5.7 学习指南:SQLyog 中的主键、列属性和数据类型
      本文介绍了 MySQL 5.7 中主键(Primary Key)和自增(Auto-Increment)的概念,以及如何在 SQLyog 中设置这些属性。同时,还探讨了数据类型的分类和选择,以及列属性的设置方法。 ... [详细]
    • 如何撰写初级和高级前端开发者的专业简历
      如何撰写初级和高级前端开发者的专业简历 ... [详细]
    • 本指南详细介绍了如何在CentOS 6.6 64位系统上以root用户身份部署Tomcat 8服务器。系统环境为CentOS 6.6 64位,采用源码安装方式。所需软件为apache-tomcat-8.0.23.tar.gz,建议将软件下载至/root/opt目录。具体下载地址请参见官方资源。本指南涵盖了从环境准备到服务启动的完整步骤,适用于需要在该系统环境下搭建高性能Web应用服务器的技术人员。 ... [详细]
    • 作为软件工程专业的学生,我深知课堂上教师讲解速度之快,很多时候需要课后自行消化和巩固。因此,撰写这篇Java Web开发入门教程,旨在帮助初学者更好地理解和掌握基础知识。通过详细记录学习过程,希望能为更多像我一样在基础方面还有待提升的学员提供有益的参考。 ... [详细]
    author-avatar
    白羊幸福的佳佳
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有