Mach-II for PHP: A Preview - Creating Views
(Page 7 of 7 )
Views are added to an application by documenting their location in mach-ii.xml, then placing the files in their designated directories (in the demo app’s case the single directory is views).
Views are called in mach-ii.xml from their respective event handlers. In the demo application, when the form is posted and the processForm listener is called, a successful result calls the showResults event handler. showResults then calls a view.
<event-handler event="showResults" access="public">
<event-arg name="pageName" value="Success" />
<view-page name="results" />
</event-handler>
Figure 12 ./config/mach-ii.xml ~ calling a view
It’s a good idea to create views that are as generic as possible so a single view can be used in many different event handlers. One obvious approach is to think of each view as a ‘component’ rather than a ‘page’. Mach-II is great for component-based layouts because <view-page> can specify its content be copied to a variable rather than display a view outright. In this way, multiple views can be generated in an event handler using the optional contentKey attribute:
<view-page name="menu" contentKey="GLOBALS['menu']" />
<view-page name="subMenu" contentKey="GLOBALS['subMenu']" />
Figure 13 ./config/mach-ii.xml ~ mapping views to global variables
The demo application’s results.php displays the result from the processForm listener’s validate method:
<? echo $GLOBALS['results']; ?>
Figure 14 ./views/results.php ~ Displaying the results from listener processForm
results.php also displays an <event-arg> defined in mach-ii.xml for the event showResults:
<? echo $event->getArg('pageName'); ?>
Figure 15 ./views/results.php ~ Displaying an <event-arg> defined in mach-ii.xml
The display file results.php:
<? $page = $event->getArg('pageName'); ?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title><? echo $page; ?></title>
</head>
<body>
<table cellpadding="0" cellspacing="0">
<tr>
<td align="left" valign="middle">
<? echo $GLOBALS['results']; ?>
</td>
</tr>
</table>
</body>
</html>
Conclusion
There are many more topics to cover that are not within the scope of this article. Among them are plugins and filters that make it possible to manipulate Event data (you’ll see them in mach-ii.xml).
Mach-II offers developers a fast, efficient and easy-to-maintain framework for object-oriented applications in PHP. At the time of the writing, Mach-II for PHP5 is in testing and will be available soon. For developers searching for a standardized design methodology for PHP web apps, Mach-II is a superior choice.
| DISCLAIMER: The content provided in this article is not warranted or guaranteed by Developer Shed, Inc. The content provided is intended for entertainment and/or educational purposes in order to introduce to the reader key ideas, concepts, and/or product reviews. As such it is incumbent upon the reader to employ real-world tactics for security and implementation of best practices. We are not liable for any negative consequences that may result from implementing any information covered in our articles or tutorials. If this is a hardware review, it is not recommended to open and/or modify your hardware. |