| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 |
- <?xml version="1.0" encoding="utf-8"?>
- <!-- EN-Revision: 24249 -->
- <!-- Reviewed: no -->
- <sect1 id="zend.feed.custom-feed">
- <title>Classes personnalisées pour les flux et entrées</title>
- <para>
- Pour finir, vous pouvez étendre les classes de <classname>Zend_Feed</classname> si
- vous souhaitez créer votre propre format ou implémenter des améliorations comme par exemple
- la gestion automatique des éléments situés dans un espace de noms personnalisé.
- </para>
- <para>
- Voici un exemple d'entrée Atom personnalisée qui gère son propre espace de noms
- <code>monen</code>. Notez aussi que la classe se charge d'appeler la méthode
- <methodname>registerNamespace()</methodname> pour que l'utilisateur n'ait au final pas du tout à se
- soucier des espaces de noms.
- </para>
- <example id="zend.feed.custom-feed.example.extending">
- <title>
- Étendre la classe représentant les entrées Atom pour ajouter la gestion d'un
- espace de noms personnalisé
- </title>
- <programlisting language="php"><![CDATA[
- /**
- * La classe personnalisée connaît automatiquement l'URI du flux
- * (qui est optionnelle) et elle peut ajouter automatiquement
- * des espaces de noms supplémentaires.
- */
- class MonEntree extends Zend_Feed_Entry_Atom
- {
- public function __construct($uri = 'http://www.exemple.com/monflux/',
- $xml = null)
- {
- parent::__construct($uri, $xml);
- Zend_Feed::registerNamespace('monen',
- 'http://www.exemple.com/monen/1.0');
- }
- public function __get($var)
- {
- switch ($var) {
- case 'maMiseAJour':
- // On traduit maMiseAJour en monen:maj
- return parent::__get('monen:maj');
- default:
- return parent::__get($var);
- }
- }
- public function __set($var, $valeur)
- {
- switch ($var) {
- case 'maMiseAJour':
- // On traduit maMiseAJour en monen:maj
- parent::__set('monen:maj', $valeur);
- break;
- default:
- parent::__set($var, $valeur);
- }
- }
- public function __call($var, $unused)
- {
- switch ($var) {
- case 'maMiseAJour':
- // On traduit maMiseAJour en monen:maMiseAJour.
- return parent::__call('monen:maMiseAJour', $unused);
- default:
- return parent::__call($var, $unused);
- }
- }
- }
- ]]></programlisting>
- <para>
- Puis pour utiliser cette classe, instanciez-la directement et définissez la
- propriété <code>maMiseAJour</code> :
- </para>
- <programlisting language="php"><![CDATA[
- $entree = new MonEntree();
- $entree->maMiseAJour = '2005-04-19T15:30';
- // appel de type méthode géré par __call
- $entree->maMiseAJour();
- // appel de type propriété géré par __get
- $entree->maMiseAJour;
- ]]></programlisting>
- </example>
- </sect1>
|