1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84
|
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.markup.getting-started">
<title>Guide de démarrage avec Zend_Markup</title>
<para>
Ce guide pour vous aider à démarrer avec <classname>Zend_Markup</classname> utilisera le parseur BBCode
et le moteur de rendu <acronym>HTML</acronym>. Les principes utilisés s'adaptent à d'autres formats.
</para>
<example id="zend.markup.getting-started.basic-usage">
<title>Utilisation classique de Zend_Markup</title>
<para>
Nous allons d'abord instancier un objet <classname>Zend_Markup_Renderer_Html</classname> en utilisant
la méthode <methodname>Zend_Markup::factory()</methodname>. Ceci créera aussi un objet
a <classname>Zend_Markup_Parser_Bbcode</classname> qui sera ajouté à l'objet de rendu.
</para>
<para>
Ensuite, nous utiliserons la méthode <methodname>render()</methodname> afin de convertir un bout de
BBCode vers du <acronym>HTML</acronym>.
</para>
<programlisting language="php"><![CDATA[
// Créer une instance de Zend_Markup_Renderer_Html,
// avec Zend_Markup_Parser_BbCode comme parseur
$bbcode = Zend_Markup::factory('Bbcode');
echo $bbcode->render('[b]bold text[/b] and [i]cursive text[/i]');
// Affiche: '<strong>bold text</strong> and <em>cursive text</em>'
]]></programlisting>
</example>
<example id="zend.markup.getting-started.complicated-example">
<title>Un exemple plus complexe de Zend_Markup</title>
<para>
Même chose ici, mais avec un bout de BBCode plus complexe.
</para>
<programlisting language="php"><![CDATA[
$bbcode = Zend_Markup::factory('Bbcode');
$input = <<<EOT
[list]
[*]Zend Framework
[*]Foobar
[/list]
EOT;
echo $bbcode->render($input);
/*
Devrait afficher quelque chose comme:
<ul>
<li>Zend Framework</li>
<li>Foobar</li>
</ul>
*/
]]></programlisting>
</example>
<example id="zend.markup.getting-started.incorrect-input">
<title>Traitement des entrées incorrectes</title>
<para>
En plus d'analyser et rendre des codes de type BBCode, <classname>Zend_Markup</classname>
peut aussi traiter les entrées non valides. La plupart des processeurs de BBCode ne sont pas
capables de rendre toute l'entrée sous forme de <acronym>XHTML</acronym> valide.
<classname>Zend_Markup</classname> corrige les entrées non valides et ajoute des tags de
fermetures si nécessaire:
</para>
<programlisting language="php"><![CDATA[
$bbcode = Zend_Markup::factory('Bbcode');
echo $bbcode->render('some [i]wrong [b]sample [/i] text');
// Remarquez que le tag '[b]' n'est pas fermé et est aussi mal niché
// dans l'arbre; mais Zend_Markup propose un rendu correct:
// some <em>wrong <strong>sample </strong></em><strong> text</strong>
]]></programlisting>
</example>
</sect1>
|