VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > Python基础教程 >
  • 带你认识 flask 的模板(2)

现在,我们来思考一个问题,如果我们每写一个逻辑,就要返回一大串 HTML代码,我们能不能把他提取出来呢?能不能像写前端那样 javascript,HTML,CSS分离开来,单独一个文件,我们需要的时候,我们再引进来。

确实是可以这样的,接下来就要用到 模板了。

 

我们接着上节课的目录创建一个 模板目录

  •  
mkdir app/templates

在下面可以看到你的第一个模板,它的功能与上面的index()视图函数返回的HTML页面相似。把这个文件写在app/templates/index.html中:

  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
<html>    <head>        <title>{{ title }} - Microblog</title>    </head>    <body>        <h1>Hello, {{ user.username }}!</h1>    </body></html>

如果不懂 HTML 可以来问我,我就是写前端出身的。

这个HTML页面看起来非常简单,唯一值得关注的地方是{{ ... }}{{ ... }}包含的内容是动态的,只有在运行时才知道具体表示成什么样子。

网页渲染转移到HTML模板之后,视图函数就能被简化:

  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
from flask import render_templatefrom app import app
@app.route('/')@app.route('/index')def index():    user = {'username': 'Miguel'}    return render_template('index.html', title='Home', user=user)

看起来好多了吧?赶紧试试这个新版本的应用程序,看看模板是如何工作的。在浏览器中加载页面后,你需要从浏览器查看HTML源代码并将其与原始模板进行比较。

将模板转换为完整的HTML页面的操作称为渲染。为了渲染模板,需要从Flask框架中导入一个名为render_template()的函数。该函数需要传入模板文件名和模板参数的变量列表,并返回模板中所有占位符都用实际变量值替换后的字符串结果。

render_template()函数调用Flask框架原生依赖的Jinja2模板引擎。Jinja2用render_template()函数传入的参数中的相应值替换{{...}}块。

我们先来看一下效果吧


相关教程