经过了第一章的内容,已经可以做出一些简单的页面,首先用这种方式做一个登录页面,首先要创建一个login的路由方法: @app.route("/login",methods=["GET"]) def 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%}
- {{blog.title}} {% endmacro%} 然后在之前的模板中: {% import 'macros.html' as macros %}
- {% for blog in blogs %} {{ macros.render_title(blog) }} {% endfor %}
这个站点的名字为 {{site_name}}
{% endblock %} 此时执行结果仍为:这个站点的名字为 myblog
现在有了模板引擎,不管怎么说,仅仅就页面层来说,已经可以很轻松的做出一些不错的功能了,但很明显,现在的界面还不是很美观,下一章将把现在主流的前端框架bootstrap与flask框架进行整合。