- [name(=(value|"value"))( attribute=(value|"value"))*]
Zend_Markup ParserZend_Markup wird aktuell mit zwei Parsern ausgeliefert, einen BBCode Parser und einen Textile Parser. Theorie des ParsensDie Parser von Zend_Markup sind Klasse die Text mit Markup in einen Token Baum konvertieren. Auch wenn wir hier den BBCode Parser als Beispiel verwenden ist die Idee des Token Baums die gleiche bei allen Parsern. Wir beginnen mit diesem Teil von BBCode als Beispiel: [b]foo[i]bar[/i][/b]baz Der BBCode Parser nimmt diesen Wert, teilt Ihn auf und erzeugt den folgenden Baum:
Wie man sieht sind die schließenden Tags weg. Sie werden nicht als Inhalt der Baumstruktur angezeigt. Das ist deswegen der Fall, da schließende Tags kein Teil des aktuellen Inhalts sind. Das bedeutet aber nicht das die schließenden Tags einfach verloren sind. Sie sind in der Tag Information für das Tag selbst gespeichert. Es ist auch zu beachten das dies nur eine vereinfachte Darstelliung des Baumes selbst ist. Der aktuelle Baum enthält viel mehr Information, wie die Attribute der Tags und deren Namen. Der BBCode ParserDer BBCode Parser ist ein Zend_Markup Parser der BBCode in einen Token Baum konvertiert. Die Syntax alle BBCode Tags ist:
Einige Beispiel von gültigen BBCode Tags sind: [b] [list=1] [code file=Zend/Markup.php] [url="http://framework.zend.com/" title="Zend Framework!"] Standardmäßig werden alle Tags durch Verwendung des Formats '[/tagname]' geschlossen. Der Textile ParserDer Textile Parser ist ein Zend_Markup Parser der Textile in einen Token Baum konvertiert. Weil Textile keine Tag Struktur hat ist nachfolgend eine Liste von Beispiel Tags:
Auch der Textile Parser wrappt alle Tags in Paragraphen; ein Paragraph endet mit zwei Leerzeilen, und wenn es mehr Tags gibt, wird ein neuer Paragraph hinzugefügt. ListenDer Textile Parser unterstützt auch zwei Typen von Listen. Den nummerischen Typ der das "#" Zeichen verwendet und Bullet-Listen welche das "*" Zeichen verwenden. Anbei ein Beispiel für beide Listen: # Element 1 # Element 2 * Element 1 * Element 2 Das obige erzeugt zwei Listen: Die erste nummeriert; und die zweite mit Punkten. In den Listen Elementen können normale Tags wie dick (*), und hochgestellt (_) verwendet werden. Tags die auf einer neuen Zeile beginnen müssen (wie 'h1' usw.) können nicht innerhalb von Listen verwendet werden.
|