Inną opcją, której użyto przed Chameleonem, udało się wczytać szablony z systemu plików, jest przekazanie "podstawowego" szablonu jako parametru.
Aby uprościć, często zawijać takie rzeczy do „tematu” obiektu:
class Theme(object):
def __init__(self, context, request):
self.context = context
self.request = request
layout_fn = 'templates/layout.pt'
@property
def layout(self):
macro_template = get_template(self.layout_fn)
return macro_template
@property
def logged_in_user_id(self):
"""
Returns the ID of the current user
"""
return authenticated_userid(self.request)
które następnie mogą być używane tak:
def someview(context, request):
theme = Theme(context, request)
...
return { "theme": theme }
które następnie mogą być wykorzystane w szablonie :
<html
xmlns="http://www.w3.org/1999/xhtml"
xmlns:tal="http://xml.zope.org/namespaces/tal"
xmlns:metal="http://xml.zope.org/namespaces/metal"
metal:use-macro="theme.layout.macros['master']">
<body>
<metal:header fill-slot="header">
...
</metal:header>
<metal:main fill-slot="main">
...
</metal:main>
</body>
</html>
dzięki. Wypróbuję rozwiązanie dzisiaj w pracy –
Chameleon obsługuje bezpośrednio szablony ładowania z systemu plików; zobacz odpowiedź udzieloną przez użytkownika1456346 –