Ostatecznie możesz rozszerzyć klasę Zend_Feed jeśli chcesz
stworzyć swój własny format lub zapewnić automatyczną obsługę elementów,
które działają w innej przestrzeni nazw.
Oto przykład własnej klasy wpisu Atom która obsługuje własną przestrzeń
nazw myns: wpisów. Zauważ, że ona także wywołuje za Ciebie
metodę registerNamespace(), dzięki czemu użytkownik końcowy
nie musi w ogóle martwić się o przestrzenie nazw.
Przykład 398. Rozszerzanie klasy wpisu Atom z własnymi przestrzeniami nazw
/**
* Własna klasa wpisu może automatycznie nadawać adres URI (opcjonalnie)
* oraz automatycznie dodawać dodatkowe przestrzenie nazw.
*/
class MyEntry extends Zend_Feed_Entry_Atom
{
public function __construct($uri = 'http://www.example.com/myfeed/',
$xml = null)
{
parent::__construct($uri, $xml);
Zend_Feed::registerNamespace('myns',
'http://www.example.com/myns/1.0');
}
public function __get($var)
{
switch ($var) {
case 'myUpdated':
// Tłumaczy myUpdated na myns:updated.
return parent::__get('myns:updated');
default:
return parent::__get($var);
}
}
public function __set($var, $value)
{
switch ($var) {
case 'myUpdated':
// Tłumaczy myUpdated na myns:updated.
parent::__set('myns:updated', $value);
break;
default:
parent::__set($var, $value);
}
}
public function __call($var, $unused)
{
switch ($var) {
case 'myUpdated':
// Tłumaczy myUpdated na myns:updated.
return parent::__call('myns:updated', $unused);
default:
return parent::__call($var, $unused);
}
}
}
Teraz aby użyć tej klasy, musisz po prostu bezpośrednio utworzyć jej
instancję i przypisać wartość właściwości myUpdated:
$entry = new MyEntry();
$entry->myUpdated = '2005-04-19T15:30';
// wywołanie w stylu metody jest obsługiwane przez funkcję __call
$entry->myUpdated();
// wywołanie w stylu właściwości jest obsługiwane przez funkcję __get
$entry->myUpdated;