1 <sect1 id="zend.view.controllers">
2 <title>Controller Scripts</title>
5 De controller is waar je Zend_View instantieert en configureert.
6 Je wijst dan variabelen aan de view toe en vertelt het view de
7 output weer te geven door middel van een bepaald script.
10 <sect2 id="zend.view.controllers.assign">
12 <title>Variabelen toewijzen</title>
15 Je controller script zou de nodige variabelen aan het view moeten
16 toewijzen voordat het de controle aan het view script overhandigd.
17 Normaal gesproken kan je toewijzingen één per één doen door
18 waarden aan de eigenschappen van de view instantie toe te wijzen:
21 <programlisting role="php"><![CDATA[<?php
22 $view = new Zend_View();
30 Dit kan wel vervelend zijn als je reeds alle waarden die
31 toegewezen moeten worden in een array of objekt voorhanden hebt.
35 de assign() methode laat je "bulk" toewijzingen doen vanaf een array
36 of objekt. De volgende voorbeelden hebben hetzelfde effekt als de
37 hierboven beschreven één per één eigenschapstoewijzingen:
40 <programlisting role="php"><![CDATA[<?php
41 $view = new Zend_View();
43 // wij een array van key/waarde-paren toe, waar de key
44 // de variabelnaam is, en de waarde de toegewezen waarde.
50 $view->assign($array);
52 // doe hetzelfde met de publieke eigenschappen van een
53 // objekt. Merk op hoe we naar een array casten bij de toewijzing.
58 $view->assign((array) $obj);
63 Anderzijds kan je de toewijzingsmethode gebruiken om
64 één per één toewijzingen te doen door een string
65 variabelnaam door te geven, en dan de variabelwaarde.
68 <programlisting role="php"><![CDATA[<?php
69 $view = new Zend_View();
70 $view->assign('a', "Hooi");
71 $view->assign('b', "Bij");
72 $view->assign('c', "Zee");
78 <sect2 id="zend.view.controllers.render">
80 <title>Een View Script weergeven</title>
83 Eenmaal je al de nodige variabelen hebt toegewezen zou de controller
84 Zend_View moeten vertellen dat het een bepaald view script moet weergeven.
85 Dat doe je door de render() methode op te roepen. Merk op dat de methide
86 het weergegeven view zal terugsturen en niet afprinten. Je moet het dus zelf
87 afprinten of echo-en wanneer dat jou past.
90 <programlisting role="php"><![CDATA[<?php
91 $view = new Zend_View();
95 echo $view->render('eenView.php');
101 <sect2 id="zend.view.controllers.script-paths">
103 <title>View Script Paden</title>
106 Standaard verwacht Zend_View dat je view scripts relatief zijn
107 tenoverstaan van het aanroepende script. Bijvoorbeeld, als je controller
108 script zich in "/map/naar/toepassing/controllers" bevindt en het roept
109 $view->render('eenView.php') op, zal Zend_View naar
110 "/map/naar/toepassing/controllers/eenView.php" zoeken.
114 waarschijnlijk zijn je scripts ergens anders ondergebracht. Om
115 Zend_View daarvan op de hoogte te brengen gebruik je de
116 setScriptPath() methode.
119 <programlisting role="php"><![CDATA[<?php
120 $view = new Zend_View();
121 $view->setScriptPath('/map/naar/toepassing/views');
126 Als je nu $view->render('eenView.php') oproept zal het naar
127 "/pad/naar/toepassing/views/eenView.php' kijken.
131 In feite kan je paden "opstapelen" door de addScriptPath()
132 methode te gebruiken. Terwijl je paden aan de stapel toevoegt
133 zal Zend_View in het meest recente pad kijken voor het
134 gevraagde view script. Dit laat je toe de standaard te overschrijven
135 met verpersoonlijkte views zodat je persoonlijke "thema's" of "skins"
136 voor sommige views kan maken terwijl die niet op andere views van
140 <programlisting role="php"><![CDATA[<?php
141 $view = new Zend_View();
142 $view->addScriptPath('/pad/naar/toepassing/views');
143 $view->addScriptPath('/pad/naar/persoonlijk/');
145 // wanneer je nu $view->render('boeklijst.php') oproept zal Zend_View
146 // eerst kijken naar "pad/naar/persoonlijk/boeklijst.php", dan naar
147 // "/pad/naar/toepassing/views/boeklijst.php", en uiteindelijk in
148 // de huidige map naar "boeklijst.php".