Zend_Feed-CustomFeed.xml 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. <sect1 id="zend.feed.custom-feed">
  2. <title>自定义Feed和条目类</title>
  3. <para>
  4. 最后,如果你想提供一个你自己的格式或者想更自动化的定义一个命名空间那么你可以扩展继承<code>Zend_Feed</code>类。
  5. </para>
  6. <para>
  7. 下面是一个用自定义Atom条目类处理<code>myns:</code>命名空间的例子。注意构造函数中已经为你调用了<code>registerNamespace()</code>,所以最终用户就可以完全不必当心命名空间了。
  8. </para>
  9. <example id="zend.feed.custom-feed.example.extending">
  10. <title>用自定义的命名空间继承Atom条目类</title>
  11. <programlisting role="php"><![CDATA[<?php
  12. /**
  13. * 自定义的条目类自动地识别feed URI(可选)
  14. * 并能自动添加额外的命名空间
  15. */
  16. class MyEntry extends Zend_Feed_Entry_Atom
  17. {
  18. public function __construct($uri = 'http://www.example.com/myfeed/',
  19. $xml = null)
  20. {
  21. parent::__construct($uri, $xml);
  22. Zend_Feed::registerNamespace('myns', 'http://www.example.com/myns/1.0');
  23. }
  24. public function __get($var)
  25. {
  26. switch ($var) {
  27. case 'myUpdated':
  28. // Translate myUpdated to myns:updated.
  29. return parent::__get('myns:updated');
  30. default:
  31. return parent::__get($var);
  32. }
  33. }
  34. public function __set($var, $value)
  35. {
  36. switch ($var) {
  37. case 'myUpdated':
  38. // Translate myUpdated to myns:updated.
  39. parent::__set('myns:updated', $value);
  40. break;
  41. default:
  42. parent::__set($var, $value);
  43. }
  44. }
  45. public function __call($var, $unused)
  46. {
  47. switch ($var) {
  48. case 'myUpdated':
  49. // Translate myUpdated to myns:updated.
  50. return parent::__call('myns:updated', $unused);
  51. default:
  52. return parent::__call($var, $unused);
  53. }
  54. }
  55. }]]>
  56. </programlisting>
  57. <para>
  58. 接下来你就可以直接实例化和设置<code>myUpdated</code>属性来使用这个类:
  59. </para>
  60. <programlisting role="php"><![CDATA[<?php
  61. $entry = new MyEntry();
  62. $entry->myUpdated = '2005-04-19T15:30';
  63. // method-style call is handled by __call function
  64. $entry->myUpdated();
  65. // property-style call is handled by __get function
  66. $entry->myUpdated;]]>
  67. </programlisting>
  68. </example>
  69. </sect1>
  70. <!--
  71. vim:se ts=4 sw=4 et:
  72. -->