Du braucht Daten? Dann nimm getText!
getText ist wohl die mächtigste Funktion, um mal eben von wo auch immer ein paar Daten herzuzaubern. Im Content-Objekt selbst heißt die Funktion getData. Schaut selbst welche Möglichkeiten angeboten werden.
Die Eigenschaft getText besteht aus mehreren Parametern. Der erste Parameter wird mit einem Doppelpunkt von allen anderen Parametern getrennt. Alle weiteren Parameter werden mit Hilfe der | Pipe unterteilt.
GP
page.10 = TEXT
page.10.data = gp:id
Dieses Beispiel gibt die aktuelle Seiten-ID wieder.
page.10 = TEXT
page.10.data = gp:tx_meineextension_pi1|artikel
Dieses Beispiel greift auf die GET-Variable tx_meineextension_pi1[artikel] zu, die von der Extension “Meine Extension” erzeugt wurde. Es wird die ID des aktuellen Artikels zurückgegeben. GP bedeutet so viel wie Get und Post. Damit könnt Ihr also auf die Variablen zugreifen, die von Seite zu Seite per URL (GET) oder per Formular (POST) übertragen werden.
GPvar
Deprecated. Bitte GP verwenden.
TSFE
10 = TEXT
10.data = TSFE:TYPO3_CONF_VARS|GFX|gdlib_2
Dieses Beispiel greift auf die Settings im Installtool zu und gibt zurück, ob die GDlib Version 2 für diese TYPO3-Installation aktiviert wurde.
10 = TEXT
10.data = TSFE:fe_user|user|username
Dieses Beispiel greift auf das Frontend-Benutzer-Array zu und gibt den Benutzernamen des aktuell angemeldeten Users zurück. TSFE ist das größte Array in TYPO3 und füllt als Ausdruck bei einer Schriftgröße von 6 über 20 Din A4-Seiten. In diesem Array sind sämtliche Settings, Scripte und Objekte definiert, die in TYPO3 verfügbar sind. Schaut selbst, was so im TSFE-Array zu finden ist.
GETENV
10 = TEXT
10.data = GETENV:SERVER_NAME
Dieses Beispiel greift auf Variablen der Serverumgebung zu. So wird hier der Servername zurückgegeben. Auf Serverseite wird die PHP-Funktion getenv ausgeführt.
GETINDPENV
10 = TEXT
10.data = GETINDPENV:SCRIPT_FILENAME
Hat die gleiche Funktion wie GETENV. Mit dem Unterschied, dass die zurückgegebenen Daten aus GETINDPENV seitens TYPO3 nochmals aufbereitet werden. Während ein GETENV:SCRIPT_FILENAME C:\xampp\htdocs\ zurückgibt, gibt ein GETINDPENV:SCRIPT_FILENAME ein sauberes C:/xampp/htdocs/ zurück.
FIELD
10 = TEXT
10.data = FIELD:title
Dieses Beispiel klappt nur, wenn es im Haupttemplate eingefügt wurde. Wenn Ihr dieses Beispiel in die Textfelder von einer Extension wie sfjquery oder ts_cobj eintragt, dann klappt das Beispiel nicht. Woran liegt das?
10.data greift immer auf den aktuellen Datensatz zu. Dieser ist im Maintemplate das Page-Objekt (Tabelle: pages). Diese enthält auch ein Feld “title”.
Aber dieses Beispiel in einer Extension kann immer nur auf das aktuelle Content-Objekt zugreifen (Tabelle: tt_content) und in dieser Tabelle gibt es keine Spalte mit dem Namen “title”. Dort heißt die Überschrift “header”:
10 = TEXT
10.data = FIELD:header
PARAMETERS
10 = TEXT
10.data = PARAMETERS:trallala
Die Parameter werden nur im Bereich von Benutzerfunctionen gefüllt. Alle Parameter die einer Funktion übergeben werden, werden in dieses Array geschrieben und können dann mit PARAMETERS in der getText-Eigenschaft wieder aufgerufen werden. Schaut Euch dazu die Funktion _parseFunc in der Datei class.tslib_content.php an.
REGISTER
10 = LOAD_REGISTER
10.variable = Hallo zusammen
20 = TEXT
20.data = REGISTER:variable
30 = TEXT
30.data = REGISTER:tx_templavoila_pi1.parentRec.uid
Das Register ist eine Art Registrierungsbereich für globale Variablen. Grade TemplaVoila nutzt dieses Register, um sämtliche Eigenschaften des Elternelements an TV-Elemente wie FCEs und TV-Templates zur Verfügung zu stellen. Natürlich kann auch mit dem TS-Objekt LOAD_REGISTER eine globale Variable angelegt werden und wie im Beispiel wieder darauf zugegriffen werden.
GLOBAL
10 = TEXT
10.data = GLOBAL:BE_USER|username
TSFE ist zwar das größte Array in TYPO3, aber wie der Name schon sagt, kann es nur auf Daten des Frontendes zugreifen. Um aber auf Daten des aktuell angemeldeten Backendusers zuzugreifen benötigen wir den Zugriff auf das Array BE_USER.
LEVELTITLE
page.10 = TEXT
page.10.data = LEVELTITLE:1
Leveltitle klappt nicht im TS von Extensions. Hier müsst Ihr Euch im Template Eurer Webseite befinden, damit das klappt.
In diesem Beispiel erhaltet Ihr den Titel der Seite aus der 2ten Ebene.
LEVELMEDIA
page.10 = TEXT
page.10.data = LEVELMEDIA:-1, slide
Levelmedia klappt nicht im TS von Extensions. Hier müsst Ihr Euch im Template Eurer Webseite befinden, damit das klappt.
In diesem Beispiel werden alle Seiten in der Rootline von rechts nach links durchlaufen bis auf einer Seite im Feld Media ein Eintrag hinterlegt wurde.
LEVELUID
page.10 = TEXT
page.10.data = LEVELUID:3
Leveluid klappt nicht im TS von Extensions. Hier müsst Ihr Euch im Template Eurer Webseite befinden, damit das klappt.
In diesem Beispiel erhaltet Ihr die UID der Seite aus der 4ten Ebene.
LEVELFIELD
page.10 = TEXT
page.10.data = LEVELFIELD:0,TSconfig
Levelfield klappt nicht im TS von Extensions. Hier müsst Ihr Euch im Template Eurer Webseite befinden, damit das klappt.
In diesem Beispiel erhaltet Ihr die TSconfig der Rootseite. Natürlich kann auch hier slide verwendet werden:
page.10 = TEXT
page.10.data = LEVELFIELD:0,TSconfig,slide
FULLROOTLINE
page.50 = TEXT
page.50.data = FULLROOTLINE:-1,title
Fullrootline klappt nicht im TS von Extensions. Hier müsst Ihr Euch im Template Eurer Webseite befinden, damit das klappt.
In diesem Beispiel erhaltet Ihr den Titel der Elternseite und NICHT die aktuelle Seite wie sonst üblich. Wenn Ihr Fullrootline “richtig” verwenden wollt, dann muss Eure Webseite aus mehreren Templates bestehen. +ext-Templates reichen aus, aber in diesen Templates MUSS das Flag “is root page” bzw. “Wurzelebene” aktiviert sein.
DATE
page.40 = TEXT
page.40.data = date:0
page.50 = TEXT
page.50.data = date:d.m.Y
Wenn date mit 0 angegeben wird, wird automatisch ein Datum im Format “d/m Y” (20/02 2010) ausgegeben. Im 2ten Beispiel wird ein Datum im Format d.m.Y (20.02.2010) ausgegeben. Es wird nicht auf die aktuelle Zeit zugegriffen, sondern auf die Zeit, als die index.php von TYPO3 geladen wurde. Heißt: Sobald die index.php von TYPO3 aufgerufen wird, wird die aktuelle Zeit in einer Variable abgespeichert EXEC_TIME. Bis dann endlich die Funktionen von getText verarbeitet werden, können ein paar Millisekunden vergangen sein.
PAGE
page.10 = TEXT
page.10.data = page:uid
In diesem Beispiel greift Ihr auf den aktuellen Seiten-Datensatz zu und holt Euch die UID der aktuellen Seite. Ihr habt auf alle Felder der pages-Tabelle Zugriff.
CURRENT
page.50 = TEXT
page.50 {
value = blau,grün,weiß,lila
split {
token = ,
cObjNum = 1
1.10 = TEXT
1.10.current = 1
1.20 = TEXT
1.20.data = current:trallala
1.wrap = <b>|</b><br />
}
}
In diesem Beispiel greifen wir auf die vom Elternelement zur Verfügung gestellten Daten zu. current = 1 und data = current:trallala haben also die gleiche Funktion. Dieses trallala oder irgendein anderer beliebiger Wert müssen angegeben werden, weil current sonst nicht ausgeführt werden kann. Auch das ist eine Unschönheit im TYPO3-Code. Denn dort werden die Funktionen nur dann ausgeführt, wenn der 2te Parameter einen Wert <> ’’ hat.
LEVEL
page.40 = TEXT
page.40.data = level:bla
page.50 = TEXT
page.50.data = level:1
Beide Beispiele geben Euch die Ebene zurück in der sich die aktuelle Seite befindet. Bitte nicht vergessen, dass bei 0 angefangen wird zu zählen. Hinter dem Doppelpunkt muss ein beliebiger Wert stehen, deshalb noch das Beispiel mit dem “bla”.
DB
page.50 = TEXT
page.50.data = DB:tt_content:106:header
Dieses Beispiel greift auf die Tabelle tt_content zu und sucht nach der UID 106. Von diesem Datensatz wird der Wert aus der Spalte “header” zurückgegeben. Alle Werte werden mit einem Doppelpunkt getrennt. Nach dem DB MÜSSEN 3 Angaben erfolgen (Tabelle, UID, Spalte), ansonsten wird nichts zurückgegeben.
LLL
page.50 = TEXT
page.50.data = lll:EXT:tt_news/locallang.xml:pi_plus_wiz_description
In diesem Beispiel greifen wir auf die Sprachdatei der tt_news-Extension zu und holen uns den Wert aus pi_plus_wiz_description. Die Ausgabe ist sprachenabhängig. Wir erhalten also eine deutsche Ausgabe bei config.language = de.
PATH
page.50 = TEXT
page.50.data = path:EXT:tt_news/res/tt_news_v2_template.html
Mit path können wir aus dem 2ten Parameter einen relativ zur TYPO3-Installation liegenden Pfadnamen erzeugen. So wird aus:
EXT:tt_news/res/tt_news_v2_template.html
typo3conf/ext/tt_news/res/tt_news_v2_template.htm
COBJ
10 = CONTENT
10 {
table = pages
select.pidInList = 5
renderObj = COA
renderObj {
10 = TEXT
10.field = title
20 = TEXT
20.data = COBJ:parentRecordNumber
}
}
COBJ beinhaltet nur den Parameter parentRecordNumber. Dieser Parameter liefert nicht wie erwartet die UID des Elternobjektes zurück, sondern ist eher als Datensatzzähler zu verstehen. So kommt es auch, dass diese Funktion nur im Bereich CONTENT und RECORD Sinn macht.
In diesem Beispiel greife ich auf eine Seite mit mehreren Unterseiten zu (5) und hole mit alle Titel der Unterseiten. Für jede Unterseite lasse ich mir auch gleich den Datensatzzähler ausgeben. Das Ergebnis schau ungefähr so aus:
- Home1
- Produkte2
- Kontakt3
- Impressum4
DEBUG
page.30 = TEXT
page.30.data = debug:rootline
page.30.wrap = |<br />
page.40 = TEXT
page.40.data = debug:fullRootLine
page.40.wrap = |<br />
page.50 = CONTENT
page.50.select.pidInList = 107
page.50.table = pages
page.50.renderObj = COA
page.50.renderObj {
10 = TEXT
10.field = title
20 = TEXT
20.data = debug:data
}
Debug kann drei Parameter interpretieren: rootline, fullRootLine und data. Data ist nicht immer gefüllt, deshalb hier auch gleich ein Beispiel, in dem data mit den Titeln der Unterseiten gefüllt wird. Aber nicht nur das. In diesem Beispiel enthält data für jede Seite ALLE Spalten der Tabelle pages.