Zend_Feed-ModifyingFeed.xml 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.feed.modifying-feed">
  5. <title>Verändern der Feed- und Eintragsstruktur</title>
  6. <para>
  7. Die natürliche Syntax von <classname>Zend_Feed</classname> wurde für das Erstellen und
  8. Verändern von Feeds und Einträgen sowie das Lesen dieser erweitert. Du kannst die neuen oder
  9. veränderten Objekte einfach in wohlgeformtes <acronym>XML</acronym> umsetzen, um es als
  10. Datei zu speichern oder an einen Server zu senden.
  11. </para>
  12. <example id="zend.feed.modifying-feed.example.modifying">
  13. <title>Verändern eines bestehenden Feed Eintrags</title>
  14. <programlisting language="php"><![CDATA[
  15. $feed = new Zend_Feed_Atom('http://atom.example.com/feed/1');
  16. $entry = $feed->current();
  17. $entry->title = 'Dies ist ein neuer Titel';
  18. $entry->author->email = 'my_email@example.com';
  19. echo $entry->saveXML();
  20. ]]></programlisting>
  21. <para>
  22. Dies gibt eine vollständige (enthält den <command>&lt;?xml ... &gt;</command> Prolog)
  23. <acronym>XML</acronym> Darstellung des neuen Eintrags aus, inklusive jedes notwendige
  24. <acronym>XML</acronym> Namensraumes.
  25. </para>
  26. <para>
  27. Beachte, dass das Obige auch funktioniert, wenn der existierende Eintrag noch keinen
  28. Autoren Tag beinhaltet. Du kannst soviele Ebenen von <command>-&gt;</command> Verweisen
  29. verwenden, wie Du möchtest, um auf eine Zuordnung zugreifen zu können; alle dieser
  30. zwischengeschalteten Stufen werden automatisch für dich erstellt wenn notwendig.
  31. </para>
  32. </example>
  33. <para>
  34. Wenn du einen anderen Namensraum als <command>atom:</command>, <command>rss:</command>, oder
  35. <command>osrss:</command> in deinem Eintrag verwenden möchtest, musst du den Namensraum mit
  36. <classname>Zend_Feed</classname> durch die Verwendung von
  37. <methodname>Zend_Feed::registerNamespace()</methodname> registrieren. Wenn du ein
  38. bestehendes Element veränderst, wird es immer den ursprünglichen Namensraum beibehalten.
  39. Wenn du ein neues Element hinzufügst, wird es den standardmäßigen Namensraum verwenden, wenn
  40. du nicht explizit einen anderen Namensraum festgelegt hast.
  41. </para>
  42. <example id="zend.feed.modifying-feed.example.creating">
  43. <title>Erstellen eines Atom Eintrags mit Elementen eines eigenen Namensraumes</title>
  44. <programlisting language="php"><![CDATA[
  45. $entry = new Zend_Feed_Entry_Atom();
  46. // Die ID wird immer vom Server in Atom zugewiesen
  47. $entry->title = 'mein eigener Eintrag';
  48. $entry->author->name = 'Beispiel Autor';
  49. $entry->author->email = 'me@example.com';
  50. // Nun erledige den eigenen Teil
  51. Zend_Feed::registerNamespace('myns', 'http://www.example.com/myns/1.0');
  52. $entry->{'myns:myelement_one'} = 'mein erster eigener Wert ';
  53. $entry->{'myns:container_elt'}->part1 = 'Erster verschachtelter Teil';
  54. $entry->{'myns:container_elt'}->part2 = 'Zweiter verschachtelter Teil';
  55. echo $entry->saveXML();
  56. ]]></programlisting>
  57. </example>
  58. </sect1>