Wiki » Historie » Version 1
Werner Hahn, 08.01.2016 12:43
1 | 1 | Werner Hahn | h1. hat das Auswirkungen ob ich in Templates [%- INCLUDE oder [% INCLUDE mache und wenn welche? |
---|---|---|---|
2 | |||
3 | nein |
||
4 | das extra minus sagt dem template system, dass das \n davor beim interpolieren gelöscht werden soll |
||
5 | so vermeidest du duzende newlines im generierten html code |
||
6 | funktional ist das identisch |
||
7 | interessantere unterscheidung ist INCLUDE vs PROCESS. die machen auch beide das gleiche, aber INCLUDE macht nen neuen variablen namespace auf, während PROCESS den aktuellen namespace weiterverwendet. das klingt trivial, ist aber ein riesiger performance unterschied, wenn du das in schleifen benutzt |
||
8 | solange dein subtemplate selber keine variablen _setzt_, also SET benutzt, solltest du immer PROCESS nehmen |
||
9 | Jein, Sven. |
||
10 | ok |
||
11 | mosu weiß mehr und erklärt |
||
12 | Weniger offensichtlich aber genau so betroffen: FOREACH |
||
13 | stimmt, implizites set |
||
14 | woernie: Wenn du ein Template mit INCLUDE inbindest, dann wirken sich sämtliche Änderungen an Variablen innerhalb des Sub-Templates auch auf das Haupttemplate auf. |
||
15 | Wenn du also z.B. im Haupttemplate so etwas machst: [% FOREACH row = SELF.items %] [% INCLUDE '_row.html' %] [% END %]… |
||
16 | …und im Sub-Template irgendwo [% FOREACH row = some_array %]… |
||
17 | …so geht das garantiert in die Hose. |
||
18 | äh |
||
19 | Quark |
||
20 | Ich meinte PROCESS in meinem Beispiel. |
||
21 | Also genau andersrum, als gorash sagt? |
||
22 | INCLUDE = alle Variablen werden kopiert, langsam, aber Änderungen im Sub-Template haben keine Auswirkungen. |
||
23 | PROCESS tut das halt nicht |
||
24 | PROCESS = schnell aber gefährlich, weil Änderungen im Sub-Template sich auf alles andere auswirken |
||
25 | Das gleiche gilt nicht nur für Sub-Templates (also Dateien), sondern auch für Blöcke, die mit [% BLOCK name %] … [% END %] deklariert und danach mit INCLUDE/PROCESS benutzt werden. |
||
26 | Meine persönliche Faustregel ist, dass alles, was in einer Schleife eingebunden wird, eher PROCESS sein sollte, alleiun aufgrund der Geschwindigkeit. Und darauf müssen die Sub-Templates dann halt designet sein. |
||
27 | Wenn man aber bei einer kompletten Seite ein gewisses Sub-Template nur ein einziges Mal einbindet, dann ist der Performanceunterschied halt nicht wirklich entscheidend (es sei denn, man hat wiederum sehr viele von solchen Sub-Templates). |
||
28 | der performance hit ist leider wirklich nicht trivial. ich hab das das erste mal bei cvar templates pro position gemerkt, und ich glaube da war der overhead im bereich 200ms für 10 positionen |
||
29 | subtemplate als block schreiben und einmal einbinden hilft tatsächlich |