Tornado框架02-模板引擎

Tornado框架中, 模板引擎能帶給我們很多方便, 它是便捷展現(xiàn)頁面的極佳方式. 在上一節(jié)中我們介紹了模板引擎對于{{}}以及對于 {%%}的用法. 我們簡單回顧一下:

**{{}}使用: **

  • 直接取服務(wù)端在render()函數(shù)中傳遞參數(shù)的值, 例如服務(wù)端中有self.render('index.html', contents=CONTENTS_LIST), 在html文件中有{{contents}} 則表示在html中取服務(wù)端的CONTENTS_LIST的內(nèi)容
  • 我們通過配置'ui_methods': 需要執(zhí)行的自定義python模塊,之后, 我們可以在html文件中通過{{自定義python模塊中的函數(shù)名()}}來執(zhí)行對應(yīng)的函數(shù)取得該函數(shù)的返回結(jié)果以此來顯示

**{%%}的使用: **

  • {%for tmp in iterable%} 用于循環(huán)語句, 注意要加上{%end%}結(jié)束語句
  • {%if condition%} 用于條件判斷, 同樣同上需要結(jié)束語句
  • 通過配置ui_modules : 需要執(zhí)行的python模塊 之后, 我們可以在文件中通過{%module python模塊名()%}來直接執(zhí)行該模塊中對應(yīng)的方法, 注意該模塊需要繼承tornado.web.UIModule

以上有不懂的請參照上一篇博客(Tornado框架01-入門總概)中的具體實(shí)例實(shí)現(xiàn)后再對應(yīng)解釋來理解

接下來我們老規(guī)矩, 先使用一下模板引擎的繼承之后, 再詳細(xì)介紹

項(xiàng)目目錄

**home.py文件如下: **

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import tornado.web


class IndexHandle(tornado.web.RequestHandler):
    def get(self, *args, **kwargs):
        self.render("extend/index.html")


class AccountHandle(tornado.web.RequestHandler):
    def get(self, *args, **kwargs):
        self.render("extend/account.html")

**acount.html文件如下: **

{%extends "../template/master.html"%}

<!--自定義css具體內(nèi)容-->
{%block tm_css%}
    <style type="text/css">
        .page-content{
            background-color: green;
        }
    </style>
{%end%}

<!--#自定義的文本內(nèi)容-->
{%block tm_content%}
    <h1>This is Account</h1>
{%end%}

<!--#自定義的js文件-->
{%block tm_js%}
    <script type="text/javascript">
        console.log('This is Account')
    </script>
{%end%}

**index.html文件如下: **

{%extends "../template/master.html"%}

<!--對應(yīng)的自定義css的具體內(nèi)容-->
{%block tm_css%}
    <style type="text/css">
        .page-content{
            background-color: yellow;
        }
    </style>
{%end%}

<!--自定義的文本內(nèi)容-->
{%block tm_content%}
    <h1>This is Index</h1>
{%end%}

<!--自定義的js文件-->
{%block tm_js%}
    <script type="text/javascript">
        console.log('This is Index')
    </script>
{%end%}

**master.html文件如下: **

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Master</title>
    <style type="text/css">
        * {
            margin: 0px;
            padding: 0px;
        }
        .page-header{
            height: 50px;
            background-color: red;
        }
        .page-content {
            height: 200px;
            background-color: azure;
        }
        .page-footer{
            height: 50px;
            background-color: black;
        }
    </style>

    <!--為后邊自定義的css命名并占位置-->
    {%block tm_css%}{%end%}
</head>
<body>
    <div class="page-header"></div>
    <div class="page-content">
        <!--自定義的內(nèi)容, 命名并占位-->
        {%block tm_content%}{%end%}
    </div>
    <div class="page-footer"></div>

    <!--自定義的js文件位置-->
    {%block tm_js%}{%end%}
</body>
</html>

**start.py文件如下: **

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import tornado.web, tornado.ioloop
from controllers import home

if __name__ == '__main__':
    CONTENTS_LIST = []
    settings = {
        'template_path': 'views',

    }

    application = tornado.web.Application([
        (r"/index", home.IndexHandle),
        (r"/account", home.AccountHandle),
    ], **settings)

    application.listen(80)
    tornado.ioloop.IOLoop.instance().start()
訪問`index`運(yùn)行結(jié)果
訪問`account`運(yùn)行結(jié)果
  • 從運(yùn)行結(jié)果來看, 兩個網(wǎng)頁的主體結(jié)構(gòu)相同, 只是里邊包含的css具體樣式, 具體內(nèi)容以及js文件不同
  • 要繼承模板文件來使用我們要在當(dāng)前文件首行寫上{%extends "../template/master.html"%} , 這里表示當(dāng)前文件以master.html來進(jìn)行渲染

{%block tm_css%}
<style type="text/css">
.page-content{
background-color: yellow;
}
</style>
{%end%}```
index.html的這部分其實(shí)就是master.htmltm_css的具體內(nèi)容

  • master.html文件中{%block tm_css%}{%end%}相當(dāng)與為后面具體要寫入的內(nèi)容做一個占位符, 并且起名為tm_css.

**使用模板的繼承可以重復(fù)使用相同結(jié)構(gòu)的模板, 可以大大減少代碼量. 但是有時候并不是所有的網(wǎng)頁結(jié)構(gòu)都是我需要的, 我們會想要單獨(dú)包含所有網(wǎng)頁都有的相同的一小部分內(nèi)容. 此時就需要模板文件的包含來實(shí)現(xiàn). **

文件目錄

**我們在剛剛的項(xiàng)目的views文件夾中加入一個include文件夾, 并且在該文件夾中新建一個form.html文件. 內(nèi)容如下: **

<form>
    <input type="text">
    <input type="submit" value="提交">
</form>

我們將index.html修改如下: **

{%extends "../template/master.html"%}

<!--對應(yīng)的自定義css的具體內(nèi)容-->
{%block tm_css%}
    <style type="text/css">
        .page-content{
            background-color: yellow;
        }
    </style>
{%end%}

<!--自定義的文本內(nèi)容-->
{%block tm_content%}
    <h1>This is Index</h1>
    {%include "../include/form.html"%}
    {%include "../include/form.html"%}
    {%include "../include/form.html"%}
{%end%}

<!--自定義的js文件-->
{%block tm_js%}
    <script type="text/javascript">
        console.log('This is Index')
    </script>
{%end%}
運(yùn)行結(jié)果
  • 從圖中看出, 我們在index.html中加上{%include "../include/form.html"%}之后, 該文件就會被包含到當(dāng)前文件中執(zhí)行一次
  • 這種包含可以重復(fù)多次, 包含次則執(zhí)行被包含的內(nèi)容一次

這里再補(bǔ)充一點(diǎn)小知識, Tornado的模板引擎默認(rèn)過濾掉xss攻擊, 當(dāng)使用{%raw content%}時, content將直接作為html內(nèi)容渲染, 不進(jìn)行轉(zhuǎn)義來避免xss攻擊

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末仆邓,一起剝皮案震驚了整個濱河市复隆,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)泄隔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宛徊,“玉大人佛嬉,你說我怎么就攤上這事≌⑻欤” “怎么了暖呕?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長苞氮。 經(jīng)常有香客問我湾揽,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任库物,我火速辦了婚禮霸旗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘戚揭。我一直安慰自己诱告,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布民晒。 她就那樣靜靜地躺著精居,像睡著了一般。 火紅的嫁衣襯著肌膚如雪镀虐。 梳的紋絲不亂的頭發(fā)上箱蟆,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天,我揣著相機(jī)與錄音刮便,去河邊找鬼。 笑死绽慈,一個胖子當(dāng)著我的面吹牛恨旱,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播坝疼,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼搜贤,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了钝凶?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎颤诀,沒想到半個月后辙喂,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡哟沫,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年饺蔑,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片嗜诀。...
    茶點(diǎn)故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡猾警,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出隆敢,到底是詐尸還是另有隱情发皿,我是刑警寧澤,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布拂蝎,位于F島的核電站穴墅,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜封救,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一拇涤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧誉结,春花似錦鹅士、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至以舒,卻和暖如春趾痘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蔓钟。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工永票, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人滥沫。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓侣集,卻偏偏與公主長得像,于是被迫代替她去往敵國和親兰绣。 傳聞我的和親對象是個殘疾皇子世分,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 譯者說 Tornado 4.3于2015年11月6日發(fā)布,該版本正式支持Python3.5的async/await...
    TaoBeier閱讀 3,044評論 0 10
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理缀辩,服務(wù)發(fā)現(xiàn)臭埋,斷路器,智...
    卡卡羅2017閱讀 134,669評論 18 139
  • 我們首先來談?wù)剋eb框架. web框架的本質(zhì)其實(shí)就是socket服務(wù)端再加上業(yè)務(wù)邏輯處理, 比如像是Tornado...
    涼茶半盞閱讀 3,152評論 1 3
  • tornado框架是一款相較于其他web framework處理服務(wù)器性能問題更加強(qiáng)健的輕量級的強(qiáng)大的Pytho...
    惡人未滿閱讀 7,127評論 3 10
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,183評論 25 707