OOP -HTML uddata
Nedenfor er vist koden for et tilfældigt PHP OOP-program med HTML-uddata: "catalog.php" - visning af katalog i e-handels site.
Programmet er underopdelt i fem grupper:
- Top Den del, der er placeret før Header.
Delen bruges til programspecifik PHP-kode. Den vil typisk indeholde instantiering af klasser, der er grundlæggende for programmet, og kode knyttet dertil. Uden at det kan ses vil extendede klasser også indgå. Top-data udføres før serveren påbegynder opbygning af HTML-siden.
- Header Den del, der via include indgår i alle programmer.
- Vil typisk indeholde 3 grupper kode:
- - Over HTML-koden vil typisk være placeret PHP-kode til instantiering etc. af de aktiviteter, der skal udeføres i Headeren: F.eks. menu.
- - Den normale DOCTYPE og Head-del.
- - Den repetitive del af siden. Den vil oftest være en blanding af HTML-kode og OOP-kode til hentning af de databasebaserede data, der skal vises.
- Side Den del, der indeholder sidens brødtekst.
Den primære præsentation af HTML- og OOP-styrede data.
- Footer Den del, der via include indgår i alle programmer.
Typisk som side, men med meget færre både HTML- og OOP-data.
- Bund Den kode, der er placeret efter Footer.
Der vil ofte ikke være data i denne del.
Ved udviklingen af en side vil det være nødvendigt at "tænke baglæns og så vidt muligt udvikle forlæns": Man designer siden så godt som muligt på rough-niveau incl. afklarer, hvilke data, der skal vises / indlægges. Derefter tænker man stadig baglæns over, hvor dataene skal komme fra, og derfra - for de data, der er afhængige af andre - afklares forholdene omkring de afhængige sata etc. Arbejdet slutter ideelt set først når man kan begynde at etablere de yderste data / den yderste kode - medmindre de allerede findes. Med den nødvendige struktur på plads og kørende nedefra kan man så arbejde sig op mod et godt slutresultat.
Top
<?php
$cat = Url::getParam('category');
if(empty($cat)) {
require_once("error.php");
} else {
$objCatalogue = new Catalogue();
$category = $objCatalogue->getCategory($cat);
if(empty($category)) {
require_once("error.php");
} else {
$rows = $objCatalogue->getProducts($cat);
// instantiate paging class
$objPaging = new Paging($rows, 3);
$rows = $objPaging->getRecords();
Header
<?php
$objCatalogue = new Catalogue();
$cats = $objCatalogue->getCategories();
$objBusiness = new Business();
$business = $objBusiness->getBusiness();
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "
http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Ecommerce website project</title>
<meta name="description" content="Ecommerce website project" />
<meta name="keywords" content="Ecommerce website project" />
<meta http-equiv="imagetoolbar" content="no" />
<link href="/css/core.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="header">
<div id="header_in">
<h5><a href="/"><?php echo $business['name']; ?></a></h5>
<?php
if (Login::isLogged(Login::$_login_front)) {
echo '<div id="logged_as">Logged in as: <strong>';
echo Login::getFullNameFront(Session::getSession(Login::$_login_front));
echo '</strong> | <a href="/?page=orders">My orders</a>';
echo ' | <a href="/?page=logout">Logout</a></div>';
} else {
echo '<div id="logged_as"><a href="/?page=login">Login</a></div>';
}
?>
</div>
</div>
<div id="outer">
<div id="wrapper">
<div id="left">
<?php require_once('basket_left.php'); ?>
<?php if (!empty($cats)) { ?>
<h2>Categories</h2>
<ul id="navigation">
  ;<?php
foreach($cats as $cat) {
echo "<li><a href=\"/?page=catalogue&category=".$cat['id']."\"";
echo Helper::getActive(array('category' => $cat['id']));
echo ">";
echo Helper::encodeHtml($cat['name']);
echo "</a></li>";
}
?>
</ul>
<?php } ?>
</div>
<div id="right">
|
Side require_once("_header.php");
?>
<h1>Catalogue :: <?php echo $category['name']; ?></h1>
<?php
if(!empty($rows)) {
foreach($rows as $row) {
?>
<div class="catalogue_wrapper">
<div class="catalogue_wrapper_left">
<?php
$image = !empty($row['image']) ?
$objCatalogue->_path.$row['image'];
$objCatalogue->_path.'unavailable.png';
$width = Helper::getImgSize($image, 0);
$width = $width > 120 ? 120 : $width;
?>
<a href="/?page=catalogue-item&category=<?php echo $category['id']; ?>&id=
<?php echo $row['id']; ?>"><img src="<?php echo $image; ?>" alt="<?php echo Helper::
encodeHtml($row['name'], 1); ?>" width="<?php echo $width; ?>" /></a>
</div> // div left slut
<div class="catalogue_wrapper_right">
<h4><a href="/?page=catalogue-item&category=<?php echo $category['id']; ?>
&id=<?php echo $row['id']; ?>"><?php echo Helper::encodeHtml($row['name'], 1); ?>
</a></h4>
<h4>Price: <?php echo Catalogue::$_currency; echo number_format($row['price'], 2); ?>
</h4>
<p><?php echo Helper::shortenString(Helper::encodeHtml($row['description'])); ?></p>
<p><?php echo Basket::activeButton($row['id']); ?></p>
</div> // div right slut
</div> // div wrapper slut
<?php
} // foreach slut
echo $objPaging->getPaging();
} else {
?>
<p>There are no products in this category.</p>
<?php
} // if empty rows slut
require_once("_footer.php");
Footer
</div>
<div class="cl"> </div>
</div>
</div>
<div id="footer">
<div id="footer_in">
© <a href="http://www.sebastiansulinski.co.uk" title="Web Design Tutorials"
target="_blank">Sebastian Sulinski</a>
</div>
</div>
<script src="/js/jquery-1.4.2.min.js" type="text/javascript"></script>
<script src="/js/basket.js" type="text/javascript"></script>
</body>
</html>
|
Bund
} // if empty $catalog slut
} // if empty $cat slut
?>
|
|