Dieser Beginner-Guide für Zend_Markup verwendet den BBCode Parser und
den HTML Renderer. Die diskutierten Prinzipien können auf andere Parser
und Renderer angewendet werden.
Beispiel 575. Grundsätzliche Verwendung von Zend_Markup
Zuerst instanzieren wir ein Zend_Markup_Renderer_Html Objekt
durch Verwendung der Zend_Markup::factory() Methode. Das
erstellt auch ein Zend_Markup_Parser_Bbcode Objekt welches dem
Renderer Objekt hinzugefügt wird.
Danach verwenden wir die render() Methode um ein Teil von
BBCode auf HTML zu konvertieren.
// Erstellt eine Instanz von Zend_Markup_Renderer_Html
// mit Zend_Markup_Parser_BbCode als seinen Parser
$bbcode = Zend_Markup::factory('Bbcode');
echo $bbcode->render('[b]bold text[/b] and [i]cursive text[/i]');
// Ausgabe: '<strong>bold text</strong> and <em>cursive text</em>'
Beispiel 576. Ein komplizierteres Beispiel von Zend_Markup
Jetzt wollen wir das gleiche wie zuerst machen, aber mit einem komplizierteren BBCode Markup.
$bbcode = Zend_Markup::factory('Bbcode');
$input = <<<EOT
[list]
[*]Zend Framework
[*]Foobar
[/list]
EOT;
echo $bbcode->render($input);
/*
Sollte etwas wie das folgende ausgeben:
<ul>
<li>Zend Framework</li>
<li>Foobar</li>
</ul>
*/
Beispiel 577. Falsche Eingaben bearbeiten
Neben dem einfachen Parsen und Darstellen von Markup wie BBCode, ist
Zend_Markup auch in der Lage falsche Eingaben zu behandeln. Die
meisten BBCode Prozessoren sind nicht in der Lage jede Eingabe zu einer gültigen
XHTML Ausgabe auszugeben. Zend_Markup
korrigiert Eingaben die falsch Verknüpft sind, und schließt auch Tags die nicht
geschlossen sind:
$bbcode = Zend_Markup::factory('Bbcode');
echo $bbcode->render('some [i]wrong [b]sample [/i] text');
// Es ist zu beachten dass das '[b]' Tag nicht geschlossen ist, und auch
// falsch verknüpft ist; trotzdem stellt es Zend_Markup korrakt wie folgt dar:
// some <em>wrong <strong>sample </strong></em><strong> text</strong>