File: Zend_Navigation-Pages-Custom.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (96 lines) | stat: -rwxr-xr-x 3,145 bytes parent folder | download | duplicates (2)
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
85
86
87
88
89
90
91
92
93
94
95
96
<?xml version="1.0" encoding="UTF-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect2 id="zend.navigation.pages.custom">
    <title>Créer des pages de type personnalisé</title>

    <para>
        Etendre <classname>Zend_Navigation_Page</classname> ne nécessite pas forcément de réécrire
        le constructeur ou les méthodes <methodname>setOptions()</methodname> ou
        <methodname>setConfig()</methodname>. Le constructeur prend un seul paramètre de type
        <type>Array</type> ou <classname>Zend_Config</classname> et il est passé à
        <methodname>setOptions()</methodname> ou <methodname>setConfig()</methodname> respectivement.
        Ces méthodes appellerons par la suite les setters <methodname>set()</methodname> qui distribueront
        leurs options. Si l'option <property>internal_id</property> est présente, alors la méthode
        <methodname>setInternalId()</methodname> sera évaluée si présente, et l'option en question lui sera
        passée. Si une telle méthode n'existe pas, l'option sera alors vue comme une propriété de la page
        et sera accessible sous <command>$internalId = $page->internal_id;</command> ou
        <command>$internalId = $page->get('internal_id');</command>.
    </para>

    <example id="zend.navigation.custom.example.simple">
        <title>La page personnalisée la plus simple possible</title>

        <para>
            La seule chose à définir dans une page personnalisée est la méthode
            <methodname>getHref()</methodname>.
        </para>

        <programlisting language="php"><![CDATA[
class My_Simple_Page extends Zend_Navigation_Page
{
    public function getHref()
    {
        return 'Quelquechose-ici--ce-que-je-veux';
    }
}
]]></programlisting>
    </example>

    <example id="zend.navigation.custom.example.properties">
        <title>Une page personnalisée avec des propriétés</title>

        <para>
            Ajouter des propriétés à vos pages étendues ne nécessite pas de réécrire
            <methodname>setOptions()</methodname> ou <methodname>setConfig()</methodname>.
        </para>

        <programlisting language="php"><![CDATA[
class My_Navigation_Page extends Zend_Navigation_Page
{
    private $_foo;
    private $_fooBar;

    public function setFoo($foo)
    {
        $this->_foo = $foo;
    }

    public function getFoo()
    {
        return $this->_foo;
    }

    public function setFooBar($fooBar)
    {
        $this->_fooBar = $fooBar;
    }

    public function getFooBar()
    {
        return $this->_fooBar;
    }

    public function getHref()
    {
        return $this->foo . '/' . $this->fooBar;
    }
}

// can now construct using
$page = new My_Navigation_Page(array(
    'label'   => 'Les noms des propriétés sont dirigés vers les setters',
    'foo'     => 'bar',
    'foo_bar' => 'baz'
));

// ...or
$page = Zend_Navigation_Page::factory(array(
    'type'    => 'My_Navigation_Page',
    'label'   => 'Les noms des propriétés sont dirigés vers les setters',
    'foo'     => 'bar',
    'foo_bar' => 'baz'
));
]]></programlisting>
    </example>
</sect2>