| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <sect1 id="zend.feed.custom-feed">
- <title>Создание собственных классов лент и записей</title>
- <para>
- Вы можете наследовать классы <code>Zend_Feed</code>, если хотите обеспечить
- собственный формат или такие улучшения, как автоматическая обработка
- элементов, которые должны находиться в специальном пространстве имен.
- </para>
- <para>
- Здесь приведен пример специального класса сообщения Atom, который управляет
- сообщениями в собственным пространстве имен <code>myns:</code>. Обратите
- внимание, что он автоматически производит вызов
- <code>registerNamespace()</code>, так что конечным пользователям не
- нужно будет беспокоиться о пространствах имен.
- </para>
- <example id="zend.feed.custom-feed.example.extending">
- <title>Расширение класса сообщения Atom с добавлением специальных пространств имен</title>
- <programlisting language="php"><![CDATA[
- /**
- * Специальный класс сообщения знает URI ленты и может автоматически
- * добавлять дополнительные пространства имен
- */
- 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':
- // преобразование myUpdated в myns:updated.
- return parent::__get('myns:updated');
- default:
- return parent::__get($var);
- }
- }
- public function __set($var, $value)
- {
- switch ($var) {
- case 'myUpdated':
- // преобразование myUpdated в myns:updated.
- parent::__set('myns:updated', $value);
- break;
- default:
- parent::__set($var, $value);
- }
- }
- public function __call($var, $unused)
- {
- switch ($var) {
- case 'myUpdated':
- // преобразование myUpdated в myns:updated.
- return parent::__call('myns:updated', $unused);
- default:
- return parent::__call($var, $unused);
- }
- }
- }
- ]]>
- </programlisting>
- <para>
- Далее для использования этого класса просто создаете его экземпляр
- и устанавливаете свойство <code>myUpdated</code>:
- </para>
- <programlisting language="php"><![CDATA[
- $entry = new MyEntry();
- $entry->myUpdated = '2005-04-19T15:30';
- // вызов в виде метода обрабатывается функцией __call
- $entry->myUpdated();
- // вызов в виде свойства обрабатывается функцией __get
- $entry->myUpdated;
- ]]>
- </programlisting>
- </example>
- </sect1>
- <!--
- vim:se ts=4 sw=4 et:
- -->
|