Zend_Navigation-Pages-Custom.xml 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect2 id="zend.navigation.pages.custom">
  4. <title>Créer des pages de type personnalisé</title>
  5. <para>
  6. Etendre <classname>Zend_Navigation_Page</classname> ne nécessite pas forcément de réécrire
  7. le constructeur ou les méthodes <methodname>setOptions()</methodname> ou
  8. <methodname>setConfig()</methodname>. Le constructeur prend un seul paramètre de type
  9. <type>Array</type> ou <classname>Zend_Config</classname> et il est passé à
  10. <methodname>setOptions()</methodname> ou <methodname>setConfig()</methodname> respectivement.
  11. Ces méthodes appellerons par la suite les setters <methodname>set()</methodname> qui distribueront
  12. leurs options. Si l'option <code>internal_id</code> est présente, alors la méthode
  13. <methodname>setInternalId()</methodname> sera évaluée si présente, et l'option en question lui sera
  14. passée. Si une telle méthode n'existe pas, l'option sera alors vue comme une propriété de la page
  15. et sera accessible sous <code>$internalId = $page->internal_id;</code> ou
  16. <code>$internalId = $page->get('internal_id');</code>.
  17. </para>
  18. <example id="zend.navigation.custom.example.simple">
  19. <title>La page personnalisée la plus simple possible</title>
  20. <para>
  21. La seule chose à définir dans une page personnalisée est la méthode
  22. <methodname>getHref()</methodname>.
  23. </para>
  24. <programlisting language="php"><![CDATA[
  25. class My_Simple_Page extends Zend_Navigation_Page
  26. {
  27. public function getHref()
  28. {
  29. return 'Quelquechose-ici--ce-que-je-veux';
  30. }
  31. }
  32. ]]></programlisting>
  33. </example>
  34. <example id="zend.navigation.custom.example.properties">
  35. <title>Une page personnalisée avec des propriétés</title>
  36. <para>
  37. Ajouter des propriétés à vos pages étendues ne nécessite pas de réécrire
  38. <methodname>setOptions()</methodname> ou <methodname>setConfig()</methodname>.
  39. </para>
  40. <programlisting language="php"><![CDATA[
  41. class My_Navigation_Page extends Zend_Navigation_Page
  42. {
  43. private $_foo;
  44. private $_fooBar;
  45. public function setFoo($foo)
  46. {
  47. $this->_foo = $foo;
  48. }
  49. public function getFoo()
  50. {
  51. return $this->_foo;
  52. }
  53. public function setFooBar($fooBar)
  54. {
  55. $this->_fooBar = $fooBar;
  56. }
  57. public function getFooBar()
  58. {
  59. return $this->_fooBar;
  60. }
  61. public function getHref()
  62. {
  63. return $this->foo . '/' . $this->fooBar;
  64. }
  65. }
  66. // can now construct using
  67. $page = new My_Navigation_Page(array(
  68. 'label' => 'Les noms des propriétés sont dirigés vers les setters',
  69. 'foo' => 'bar',
  70. 'foo_bar' => 'baz'
  71. ));
  72. // ...or
  73. $page = Zend_Navigation_Page::factory(array(
  74. 'type' => 'My_Navigation_Page',
  75. 'label' => 'Les noms des propriétés sont dirigés vers les setters',
  76. 'foo' => 'bar',
  77. 'foo_bar' => 'baz'
  78. ));
  79. ]]></programlisting>
  80. </example>
  81. </sect2>