Python的web模板,其实就是在HTML文档中使用控制语句和表达语句替换HTML文档中的变量来控制HTML的显示格式,Python的web模板可以更加灵活和方便的控制HTML的显示,而且大大地减少了编程人员的工作量。
模板语法:
1、控制语句{% ... %}:控制语句需要用{% end %}来作为此语句结束标志,通常用来作循环控制、条件控制、模块控制等,可以更加方便的控制HTML内容的显示;
2、表达语句{{ ... }}:一条表达语句就相当于一条Python语句,不需要结束语句,{{和}}之间可以放入任何Python表达式,Python模板语法可以自动运行{{和}}中的语句并把运行结果显示在HTML模板中;
3、母板继承:在母板中使用{% block block_name %}{% end %}进行模块的占位,block_name可以自己定义,其他的都是固定的语法格式;在子模板中使用{% extends "xxx.html" %}表示此HTML模板继承自“xxx.html”模板(母板),然后在子模板中使用{% block block_name %} ... {% end %}重新定义母板中占位的模块,子模板中定义模块内容就会显示在母板中占位的位置,不同的子模板中可以定义不同的模块内容来满足自身的需要;
4、模板导入:在一个HTML模板中使用{% include "xxx.html" %},就会将xxx.html的内容导入(嵌入)当前HTML模板中,一般会将一些公共内容写在一个模板中,然后导入到需要使用的模板中,以达到代码重用的效果,使模板编码更加简洁方便;
5、模板函数:
1)static_url("static_file_path"):导入静态文件,参数为静态文件的路径全名,例如<link href="{{ static_url("xxx.css") }}" rel="stylesheet" />,如果设置了静态文件路径(比如tornado.web.Application中参数settings的选项static_path),则该参数为设置的静态文件路径下的相对路径;
2)escape(string):将string中的$、<和>转换成对应的HTML字符串;
3)更新中...
下面是用tornado写的一个非常简单的web模板应用:
1 #!/usr/bin/env python 2 # -*- coding: utf-8 -*- 3 import tornado.web 4 import tornado.ioloop 5 6 from tornado.options import define, options 7 8 define('port', default=8888, help='run on give the give port', type=int) 9 10 11 # 用于处理网页的请求 12 class MainHandler(tornado.web.RequestHandler): 13 def get(self, *args, **kwargs): 14 personinfodict = { 15 'name': 'Jason', 16 'age': 20, 17 'gender': 'male', 18 } 19 itemlist = ['name', 'age', 'gender'] 20 # 将变量以参数的形式传入HTML模板中 21 self.render('personinfo.html', itemlist=itemlist, personinfodict=personinfodict, welcome='hello guy!') 22 23 24 # 设置不同路由的网页对应的处理类 25 app = tornado.web.Application([ 26 (r'/', MainHandler) 27 ]) 28 29 # 开始主程序I/O循环 30 if __name__ == '__main__': 31 app.listen(options.port) 32 tornado.ioloop.IOLoop.instance().start()
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <!-- 使用表达语句输出变量的值 --> 6 <title>{{ welcome }}</title> 7 </head> 8 <body> 9 <ul><!-- 使用控制语句控制HTML内容的输出,也减少了许多工作量 --> 10 {% for item in itemlist %} 11 <li>{{ item }}: {{ personinfodict[item] }}</li> 12 {% end %} 13 </ul> 14 </body> 15 </html>