Zend_Feed-CustomFeed.xml 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <sect1 id="zend.feed.custom-feed">
  2. <title>Własne klasy kanału i wpisu</title>
  3. <para>
  4. Ostatecznie możesz rozszerzyć klasę <code>Zend_Feed</code> jeśli chcesz
  5. stworzyć swój własny format lub zapewnić automatyczną obsługę elementów,
  6. które działają w innej przestrzeni nazw.
  7. </para>
  8. <para>
  9. Oto przykład własnej klasy wpisu Atom która obsługuje własną przestrzeń
  10. nazw <code>myns:</code> wpisów. Zauważ, że ona także wywołuje za Ciebie
  11. metodę <code>registerNamespace()</code>, dzięki czemu użytkownik końcowy
  12. nie musi w ogóle martwić się o przestrzenie nazw.
  13. </para>
  14. <example id="zend.feed.custom-feed.example.extending">
  15. <title>Rozszerzanie klasy wpisu Atom z własnymi przestrzeniami nazw</title>
  16. <programlisting role="php"><![CDATA[
  17. /**
  18. * Własna klasa wpisu może automatycznie nadawać adres URI (opcjonalnie)
  19. * oraz automatycznie dodawać dodatkowe przestrzenie nazw.
  20. */
  21. class MyEntry extends Zend_Feed_Entry_Atom
  22. {
  23. public function __construct($uri = 'http://www.example.com/myfeed/',
  24. $xml = null)
  25. {
  26. parent::__construct($uri, $xml);
  27. Zend_Feed::registerNamespace('myns',
  28. 'http://www.example.com/myns/1.0');
  29. }
  30. public function __get($var)
  31. {
  32. switch ($var) {
  33. case 'myUpdated':
  34. // Tłumaczy myUpdated na myns:updated.
  35. return parent::__get('myns:updated');
  36. default:
  37. return parent::__get($var);
  38. }
  39. }
  40. public function __set($var, $value)
  41. {
  42. switch ($var) {
  43. case 'myUpdated':
  44. // Tłumaczy myUpdated na myns:updated.
  45. parent::__set('myns:updated', $value);
  46. break;
  47. default:
  48. parent::__set($var, $value);
  49. }
  50. }
  51. public function __call($var, $unused)
  52. {
  53. switch ($var) {
  54. case 'myUpdated':
  55. // Tłumaczy myUpdated na myns:updated.
  56. return parent::__call('myns:updated', $unused);
  57. default:
  58. return parent::__call($var, $unused);
  59. }
  60. }
  61. }
  62. ]]>
  63. </programlisting>
  64. <para>
  65. Teraz aby użyć tej klasy, musisz po prostu bezpośrednio utworzyć jej
  66. instancję i przypisać wartość właściwości <code>myUpdated</code>:
  67. </para>
  68. <programlisting role="php"><![CDATA[
  69. $entry = new MyEntry();
  70. $entry->myUpdated = '2005-04-19T15:30';
  71. // wywołanie w stylu metody jest obsługiwane przez funkcję __call
  72. $entry->myUpdated();
  73. // wywołanie w stylu właściwości jest obsługiwane przez funkcję __get
  74. $entry->myUpdated;
  75. ]]>
  76. </programlisting>
  77. </example>
  78. </sect1>