Zend_Feed-ModifyingFeed.xml 3.0 KB

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