Tornado模板

--------------------静态文件--------------------
一、static_path:经过向web.Application类的构造函数传递一个名为static_path的参数来告诉Tornado从文件系统的一个特定位置提供静态文件
    app = tornado.web.Application(
        [(r'/', IndexHandler)],
        static_path=os.path.join(os.path.dirname(__file__), "statics"),
    )
 
二、对于静态文件目录的命名,为了便于部署,建议使用static
    能够经过http://127.0.0.1/static/html/index.html来访问。并且在index.html中引用的静态资源文件,咱们给定的路径也符合/static/...的格式,故页面能够正常浏览。
 
三、StaticFileHandler:能够经过tornado.web.StaticFileHandler来自由映射静态文件与其访问路径url。
    一、tornado.web.StaticFileHandler是tornado预置的用来提供静态资源文件的handler。
 
    二、
    import os
 
    current_path = os.path.dirname(__file__)
    app = tornado.web.Application(
        [
            (r'^/()$', StaticFileHandler, {"path":os.path.join(current_path, "statics/html"), "default_filename":"index.html"}),
            (r'^/view/(.*)$', StaticFileHandler, {"path":os.path.join(current_path, "statics/html")}),
        ],
        static_path=os.path.join(current_path, "statics"),
    )
 
    三、path 用来指明提供静态文件的根路径,并在此目录中寻找在路由中用正则表达式提取的文件名。
 
    四、default_filename 用来指定访问路由中未指明文件名时,默认提供的文件。
 
 
--------------------使用模板--------------------
一、路径与渲染
    一、使用模板,须要仿照静态文件路径设置同样,向web.Application类的构造函数传递一个名为template_path的参数来告诉Tornado从文件系统的一个特定位置提供模板文件
 
    二、
    app = tornado.web.Application(
        [(r'/', IndexHandler)],
        static_path=os.path.join(os.path.dirname(__file__), "statics"),
        template_path=os.path.join(os.path.dirname(__file__), "templates"),
    )
 
    三、在handler中使用render()方法来渲染模板并返回给客户端。
        self.render("index.html") # 渲染主页模板,并返回给客户端。
 
二、模板语法
    一、变量与表达式
        一、在tornado的模板中使用{{}}做为变量或表达式的占位符,使用render渲染后占位符{{}}会被替换为相应的结果值。
            self.render("index.html",**kwargs)
 
        二、{{}}不只能够包含变量,还能够是表达式
            self.render("index.html",{"p1":100,"p2":200})
 
            {{p1 + p2}}
 
    二、控制语句
        一、在Tornado模板中使用Python条件和循环语句。控制语句以{\%和\%}包围,并以相似下面的形式被使用:
            {% if page is None %} 或 {% if len(entries) == 3 %}
 
        二、部分控制语句
            一、{% if ... %} ... {% elif ... %} ... {% else ... %} ... {% end %}
 
            二、{% for ... in ... %} ... {% end %}
 
            三、{% while ... %} ... {% end %}
 
    三、函数
        一、static_url():Tornado模板模块提供了一个叫做static_url的函数来生成静态文件目录下文件的URL。
            一、使用方法
            <link rel="stylesheet" href="{{ static_url("style.css") }}">
 
            二、static_url函数建立了一个基于文件内容的hash值,并将其添加到URL末尾(查询字符串的参数v)。这个hash值确保浏览器老是加载一个文件的最新版而不是以前的缓存版本。不管是在你应用的开发阶段,仍是在部署到生产环境使用时,都很是有用,由于你的用户没必要再为了看到你的静态内容而清除浏览器缓存了。
 
            三、另外一个好处是你能够改变你应用URL的结构,而不须要改变模板中的代码。例如,能够经过设置static_url_prefix来更改Tornado的默认静态路径前缀/static。若是使用static_url而不是硬编码的话,代码不须要改变。
 
        二、转义
            一、模板中能够经过raw语句来输出不被转义的原始格式
 
            二、注意:在Firefox浏览器中会直接弹出alert窗口,而在Chrome浏览器中,须要set_header("X-XSS-Protection", 0)
 
            三、关闭自动转义:
                一、Application中设置autoescape=None
 
                二、模板中添加 {% autoescape None %} 语句
 
            四、关闭自动转义后,可使用escape()函数来对特定变量进行转义:{{ escape(text) }}
 
        三、自定义函数:在模板中还可使用一个本身编写的函数,只须要将函数名做为模板的参数传递便可,就像其余变量同样。
            一、定义函数
            def house_title_join(titles):
                return "+".join(titles)
 
            二、将函数赋值到指定变量传递到模板
            self.render("index.html", houses=house_list, title_join = house_title_join)
 
            三、前端调用指定的函数,并传入对应的参数
            {{title_join(house["titles"])}}
 
    四、块
        一、进行模板页的嵌套
            一、指定继承的模板页
                {% extends "base.html" %}
            二、定义对应的模块,子模板继承父级模板进行对应的替换操做
                {% block block_name %} {% end %}
相关文章
相关标签/搜索