Feldname an Callback übergeben: Unterschied zwischen den Versionen
Aus Contao Community Documentation
K (TL -> contao) |
|||
Zeile 4: | Zeile 4: | ||
Dank der PHP Methode "__call" kann man aber der Klasse diese Möglichkeit nachrüsten: | Dank der PHP Methode "__call" kann man aber der Klasse diese Möglichkeit nachrüsten: | ||
− | < | + | <source lang="php"> |
/** | /** | ||
* Automatic callback functions for every field | * Automatic callback functions for every field | ||
Zeile 19: | Zeile 19: | ||
} | } | ||
} | } | ||
− | </ | + | </source> |
Die Methoden "load_field" und "save_field" bekommen nun als ersten Parameter den Feldnamen übergeben. Man muss nur dafür sorgen, dass das callback der Felder der Form load_''feldname'' bzw. save_''feldname'' folgt. | Die Methoden "load_field" und "save_field" bekommen nun als ersten Parameter den Feldnamen übergeben. Man muss nur dafür sorgen, dass das callback der Felder der Form load_''feldname'' bzw. save_''feldname'' folgt. | ||
Zeile 25: | Zeile 25: | ||
Wenn man z.B. allen Feldern der Tabelle tl_page ein callback mitgeben will, kann man es so machen: | Wenn man z.B. allen Feldern der Tabelle tl_page ein callback mitgeben will, kann man es so machen: | ||
− | < | + | <source lang="php"> |
foreach ($GLOBALS['TL_DCA']['tl_page']['fields'] as $strFieldName => $arrField) | foreach ($GLOBALS['TL_DCA']['tl_page']['fields'] as $strFieldName => $arrField) | ||
{ | { | ||
Zeile 31: | Zeile 31: | ||
$GLOBALS['TL_DCA']['tl_page']['fields'][$strFieldName]['save_callback'][] = array('DMAPublishCallback','load_'.$strFieldName); | $GLOBALS['TL_DCA']['tl_page']['fields'][$strFieldName]['save_callback'][] = array('DMAPublishCallback','load_'.$strFieldName); | ||
} | } | ||
− | </ | + | </source> |
Version vom 3. Oktober 2010, 14:20 Uhr
Wenn man viele Felder in einem Backend-Formular per load_callback oder save_callback manipulieren will, müsste man eigentlich für jedes Feld eine eigene Callback-Funktion schreiben. Wenn man aber in jedem Fall prinzipiell die selbe Manipulation vornimmt (z.B. die Daten statt aus der Datenbank woanders einzulesen), ist es sinnvoller, immer die selbe Funktion zu nutzen. Leider übergibt Contao diesem callback, aber nicht den Feldnamen.
Dank der PHP Methode "__call" kann man aber der Klasse diese Möglichkeit nachrüsten:
/** * Automatic callback functions for every field * loads or saves the values */ public function __call($name,$args) { list($type,$field) = explode('_',$name,2); switch($type) { case 'load': return $this->load_field($field,$args[0]); break; case 'save': return $this->save_field($field,$args[0]); } }
Die Methoden "load_field" und "save_field" bekommen nun als ersten Parameter den Feldnamen übergeben. Man muss nur dafür sorgen, dass das callback der Felder der Form load_feldname bzw. save_feldname folgt.
Wenn man z.B. allen Feldern der Tabelle tl_page ein callback mitgeben will, kann man es so machen:
foreach ($GLOBALS['TL_DCA']['tl_page']['fields'] as $strFieldName => $arrField) { $GLOBALS['TL_DCA']['tl_page']['fields'][$strFieldName]['load_callback'][] = array('DMAPublishCallback','load_'.$strFieldName); $GLOBALS['TL_DCA']['tl_page']['fields'][$strFieldName]['save_callback'][] = array('DMAPublishCallback','load_'.$strFieldName); }