另外一類常用的模板標(biāo)簽是通過(guò)渲染 其他 模板顯示數(shù)據(jù)的。 比如說(shuō),Django的后臺(tái)管理界面,它使用了自定義的模板標(biāo)簽來(lái)顯示新增/編輯表單頁(yè)面下部的按鈕。 那些按鈕看起來(lái)總是一樣的,但是鏈接卻隨著所編輯的對(duì)象的不同而改變。 這就是一個(gè)使用小模板很好的例子,這些小模板就是當(dāng)前對(duì)象的詳細(xì)信息。
這些排序標(biāo)簽被稱為 包含標(biāo)簽 。如何寫(xiě)包含標(biāo)簽最好通過(guò)舉例來(lái)說(shuō)明。 讓我們來(lái)寫(xiě)一個(gè)能夠產(chǎn)生指定作者對(duì)象的書(shū)籍清單的標(biāo)簽。 我們將這樣利用標(biāo)簽:
{% books_for_author author %}
結(jié)果將會(huì)像下面這樣:
- The Cat In The Hat
- Hop On Pop
- Green Eggs And Ham
首先,我們定義一個(gè)函數(shù),通過(guò)給定的參數(shù)生成一個(gè)字典形式的結(jié)果。 需要注意的是,我們只需要返回字典類型的結(jié)果就行了,不需要返回更復(fù)雜的東西。 這將被用來(lái)作為模板片段的內(nèi)容:
def books_for_author(author): books = Book.objects.filter(authors__id=author.id) return {'books': books}
接下來(lái),我們創(chuàng)建用于渲染標(biāo)簽輸出的模板。 在我們的例子中,模板很簡(jiǎn)單:
-
{% for book in books %}
- {{ book.title }} {% endfor %}
最后,我們通過(guò)對(duì)一個(gè) Library 對(duì)象使用 inclusion_tag() 方法來(lái)創(chuàng)建并注冊(cè)這個(gè)包含標(biāo)簽。
在我們的例子中,如果先前的模板在 polls/result_snippet.html 文件中,那么我們這樣注冊(cè)標(biāo)簽:
register.inclusion_tag('book_snippet.html')(books_for_author)
Python 2.4裝飾器語(yǔ)法也能正常工作,所以我們可以這樣寫(xiě):
@register.inclusion_tag('book_snippet.html') def books_for_author(author): # ...
有時(shí)候,你的包含標(biāo)簽需要訪問(wèn)父模板的context。 為了解決這個(gè)問(wèn)題,Django為包含標(biāo)簽提供了一個(gè) takes_context 選項(xiàng)。 如果你在創(chuàng)建模板標(biāo)簽時(shí),指明了這個(gè)選項(xiàng),這個(gè)標(biāo)簽就不需要參數(shù),并且下面的Python函數(shù)會(huì)帶一個(gè)參數(shù): 就是當(dāng)這個(gè)標(biāo)簽被調(diào)用時(shí)的模板context。
例如,你正在寫(xiě)一個(gè)包含標(biāo)簽,該標(biāo)簽包含有指向主頁(yè)的 home_link 和 home_title 變量。 Python函數(shù)會(huì)像這樣:
@register.inclusion_tag('link.html', takes_context=True) def jump_link(context): return { 'link': context['home_link'], 'title': context['home_title'], }
(注意函數(shù)的第一個(gè)參數(shù) 必須 是 context 。)
模板 link.html 可能包含下面的東西:
Jump directly to {{ title }} .
然后您想使用自定義標(biāo)簽時(shí),就可以加載它的庫(kù),然后不帶參數(shù)地調(diào)用它,就像這樣:
{% jump_link %}
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
