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 12.7. Rozszerzanie klasy wpisu Atom z własnymi przestrzeniami nazw
<?php /** * 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); } } } ?>
Teraz aby użyć tej klasy, musisz po prostu bezpośrednio utworzyć jej
instancję i przypisać wartość właściwości myUpdated
:
<?php $entry = new MyEntry(); $entry->myUpdated = '2005-04-19T15:30'; ?>