flask web 笔记 静态文件及渲染模板-文件无法渲染

flask web 笔记 静态文件及渲染模板

静态文件

动态的 web 应用同样需要静态文件。CSS 和 JavaScript 文件通常来源于此。理想情况下,你的 web 服务器已经配置好为它们服务,然而在开发过程中 Flask 就能够做到。只要在你的包中或模块旁边创建一个名为static 的文件夹,在应用中使用 /static 即可访问。

给静态文件生成 URL ,使用特殊的 static 端点名:

url_for('static', filename='style.css')

这个文件是应该存储在文件系统上的static/style.css。

在 Python 中生成 HTML 并不好玩,实际上是相当繁琐的,因为你必须自行做好 HTML 转义以保持应用程序的安全。由于这个原因,Flask 自动为你配置好 Jinja2 模板。

你可以使用方法 render_template() 来渲染模板。所有你需要做的就是提供模板的名称以及你想要作为关键字参数传入模板的变量。

这里有个渲染模板的简单例子,在 /home/mysite/Code 目录下新建 hello.py 文件,并向其中添加如下代码:

flask web 笔记 静态文件及渲染模板

Flask 将会在 templates 文件夹中寻找模板。因此如果你的应用是个模块,这个文件夹在模块的旁边,如果它是一个包,那么这个文件夹在你的包里面:

比如,应用是模块:

flask web 笔记 静态文件及渲染模板

比如,应用是包:

/application
/__init__.py
/templates
/hello.html

对于模板,你可以使用 Jinja2 模板的全部能力。详细信息查看官方的 Jinja2 Template Documentation 。

在 /home/mysite/Code 目录下新建 templates 文件夹并在其中新建 hello.html 文件:

flask web 笔记 静态文件及渲染模板

照前面的方法运行应用程序,当访问 http://127.0.0.1:5000/hello/ 时页面显示 Hello World!;当访问 http://127.0.0.1:5000/hello/shiyanlou 时页面显示 Hello shiyanlou!。

在模板中你也可以使用request,session和g对象,也能使用函数get_flashed_messages() 。

模板继承是十分有用的。如果想要知道模板继承如何工作的话,请阅读文档模板继承。基本的模板继承使得某些特定元素(如标题、导航和页脚)在每一页成为可能。

自动转义默认是开启的,因此如name包含 HTML,它将会自动转义。如果你信任一个变量,并且你知道它是安全的(例如一个模块把 wiki 标记转换到 HTML ),你可以用Markup类或|safe过滤器在模板中标记它是安全的。 在 Jinja 2 文档中,你会见到更多例子。

下面有一个Markup类如何工作的基本介绍,在 Python3 交互式命令行中执行如下命令:

flask web 笔记 静态文件及渲染模板

推荐阅读