HTML代码和PHP分离

使用PHP4中的 IntegratedTemplate类实现HTML和PHP代码分离

    使用PHP编程的人都会碰到这样一个问题:当PHP代码和HTML代码在一起的时候,看PHP代码很费劲,整个文件也无法用Dreamweaver来编辑,这对于PHP程序员和美工来讲,修改这样的文件就象一个噩梦。
    PHP中的模板(Template)技术就是为了解决这个问题而出现的。PHP模板类有很多,比较常见的是 FastTemplate 和 PHPLib, 因为出现得早,在PHP编程界名声很大。PHP程序员不知道这两个类,就象VB程序员不知道MsgBox函数一样,是一件不可思议的事情。
    以前我们需要去下载PHP模板类,现在PHP4有了自己的模板类 IntegratedTemplate 和 IntegratedTemplateExtension,功能和PHPLib 差不多。这两个类是子类和父类的关系。一般我们用 IntegratedTemplateExtension 就可以了。让人感到不可思议的是 IntegratedTemplate 不是从 PEAR 类继承过来,无法用到 PEAR 类的 debug 功能。
    以下举例子说明它们的用法,假设 IntegratedTemplate 类和 IntegratedTemplateExtension 类分别在 C:/php4/pear/HTML/ITX.php 和 C:/php4/pear/HTML/ITX.php 中。我们写的代码放在C:/TestPHP/PHP4/Welcome.htm 和 C:/TestPHP/HTML/Welcome.php 中。将C:/TestPHP/PHP4 在Web Server 上设成虚拟目录 /testphp 并且给与脚本执行权限,确认C:/TestPHP/HTML/Welcome.htm 无法通过远端浏览器访问。在 php.ini 里面设置 include_path = ".;C:/php4/pear"
    例1:
    我们在HTML文件中放置变量的标记,用PHP代码设置变量的值,然后将HTML中的标记替换掉,最后输出到客户浏览器。
    以下是 Welcome.htm 代码,我们放了三个PHP tag(变量标记)为: {WelcomeTitle}、{UserName}、{WelcomeMessage}

  <html>
<head>
<title>{WelcomeTitle}</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<style type="text/css">
<!--
body,p,br,div,td,table { font-size: 9pt}
-->
</style>
</head>

<body bgcolor="#FFFFFF" text="#000000">
<p align="center">您好,{UserName}</p>
<p align="center">{WelcomeMessage} </p>
</body>
</html>

 


    以下是Welcome.php代码

  <?php
require_once "HTML/ITX.php";

//以下是给变量赋值,在实际代码中可能从Database中取得数据然后赋值
$WelcomeTitle = "欢迎来到网页天堂";
$UserName = "皮皮鲁";
$WelcomeMessage = "您的到来让我们深感荣幸!";

//一般来说这种全局变量放在单独的一个文件中,便于维护
$HTML_CODE_FILE_ROOT = "../HTML/";

$tpl = new IntegratedTemplateExtension($HTML_CODE_FILE_ROOT);

//指定要替换 tag 的 HTML 文件
$tpl->loadTemplatefile("Welcome.htm");

//替换HTML 文件中的 tag
$tpl->setVariable( array (
    "WelcomeTitle" => $WelcomeTitle,
    "UserName" =>$UserName,
    "WelcomeMessage" =>$WelcomeMessage
    ) );

//输出替换后的 HTML
$tpl->show();
?>
 


    这样写好后,Welcome.htm 仍然可以使用网页编辑器如Dreamweaver、FrontPage 进行编辑,Welcome.php中是纯粹的PHP代码,不含HTML,方便以后的代码修改和维护。
    如果将 IntegratedTemplateExtension 类和 PHP4中的 Cache 类 联合使用,在速度上可以得到很好的效果。
PHP4 模板类还可以使用 Block,配合其他 PHP4 中的类 可以很轻松地实现数据库数据检索的翻页,可以很轻松写出论坛之类的软件。

    补充说明:为了防止用户直接用 Welcome.htm 看网页,将 Welcome.htm 放在客户访问不到的目录(只要不在Web Server 的虚拟目录下即可)。对于大型的PHP项目,图片、PHP代码、HTML文件、多语言字符串文件都应该放在不同的目录,这样在多人共同做一个项目时不至于混乱。

 

=======================================================================


使用PHP4中的 IntegratedTemplate类实现BLOCK功能

    关键字:PHP4,template,模板,IntegratedTemplateExtension,block
    读者要求:了解PHP4 的模板概念

    使用PHP 模板类进行编程很有好处,但是有时也会碰到一个问题,比如说输出一个表格,但是表格行数要到运行的时候才知道,如留言板、BBS、购物网站之类,经常会碰到这个问题。这时做美工的人无法决定在HTML文件中用几行表格,如果在PHP代码文件中写循环输出,又会让美工、PHP程序员看代码都不方便,美工的人会说,这里的表格哪里去了?我要修改表格的颜色背景之类怎么办?PHP程序员也会说,怎么这里突然有一个<tr>、<td>,做什么用?会嵌在HTML文件哪里?。
    使用PHP模板类编程一般把这种不确定个数的HTML 元素当成一个“ block ”,对 bolck 的编程类似于在代码中写一个循环。在比较常用的PHP模板类(如 FastTemplate 和 PHPLib )都有这种功能。写嵌套的block 类似于写多重循环。现在举例说明在 PHP4 里面的 IntegratedTemplateExtension 类中block 的编程方法,例子中用的是两重循环,外层block 是GoodsList,里层block 是GoodsListOfSomeType 。
    基本设置:假设我们写的代码放在C:/TestPHP/PHP4/GoodsList.htm 和 C:/TestPHP/HTML/GoodsList.php 中。将C:/TestPHP/PHP4 在Web Server 上设成虚拟目录 /testphp 并且给与脚本执行权限,确认C:/TestPHP/HTML/GoodsList.htm 无法通过远端浏览器访问。假定PHP4安装在C:/php4,在 php.ini 里面设置 include_path = ".;C:/php4/pear"


    以下是GoodsList.htm的内容:

  <html>
<head>
<title>购物袋里的商品清单</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<style type="text/css">
<!--
body,p,br,td,tr,table { font-size: 9pt}
-->
</style>
</head>

<body bgcolor="#FFFFFF" text="#000000">
<table width="700" border="0" cellspacing="0" cellpadding="0" height="90">
    <tr>
        <td colspan="5">&nbsp;</td>
    </tr>
    <tr>
        <td colspan="5">
        <div align="center">{UserName},您的购物袋里有以下商品:</div>
        </td>
    </tr>
    <tr>
        <td colspan="5">
            <hr>
        </td>
    </tr>
    <tr>
        <td width="52">&nbsp;</td>
        <td width="302">商品种类</td>
        <td width="302">商品名称</td>
        <td width="299">商品价格</td>
        <td width="47">&nbsp;</td>
    </tr>
    <!-- BEGIN GoodsList --> <!-- 说明: block 商品列表开始 -->
    <tr bgcolor="#99CCFF">
        <td width="52">&nbsp;</td>
        <td width="302"><font color="#CC0066">{Type}</font></td>
        <td width="302">&nbsp;</td>
        <td width="299">&nbsp;</td>
        <td width="47">&nbsp;</td>
    </tr>
    <!-- BEGIN GoodsListOfSomeType --> <!-- 说明: block 某一类商品列表开始 -->
    <tr>
        <td width="52">&nbsp;</td>
        <td width="302">&nbsp;</td>
        <td width="302">{GoodsName}</td>
        <td width="299">{Price}</td>
        <td width="47">&nbsp;</td>
    </tr>
    <!-- END GoodsListOfSomeType --> <!-- 说明: block 某一类商品列表结束 -->
    <!-- END GoodsList --> <!-- 说明: block 商品列表结束 -->
    <tr>
        <td colspan="5">&nbsp;</td>
    </tr>
</table>
<p>&nbsp;</p>
</body>
</html>

 
   


    以下是PHP4代码文件 GoodsList.php

  <?php
require_once "HTML/ITX.php";

//以下是给变量赋值,在实际代码中可能从Database中取得数据然后赋值
$UserName = "皮皮鲁";
$GoodsTypeArray = array("家电", "书籍");
$GoodsNameArray = array(array("三星显示器", "Sony单放机","长虹彩电"),
    array("C++ 编程思想", "Java 2 高级开发指南", "Visual Basic 5 高级开发指南",
    "Flash 4 快闪劲爆网页", "设计模式可复用面向对象软件的基础" ));
$GoodsPriceArray = array(array(1024, 302, 1024),
    array(35, 62, 76, 66.5, 55 ));

//一般来说这种全局变量放在单独的一个文件中,便于维护
$HTML_CODE_FILE_ROOT = "../HTML/";

$tpl = new IntegratedTemplateExtension($HTML_CODE_FILE_ROOT);

//指定要替换 tag 的 HTML 文件
$tpl->loadTemplatefile("GoodsList.htm");

$tpl->setVariable("UserName",$UserName); //用户名称

//指定外层 block 名称
$tpl->setCurrentBlock("GoodsList");
//我喜欢在循环前将循环次数单独赋值
$GoodsTypeCount = count($GoodsTypeArray);

//对外层block 进行循环
for ($i = 0 ; $i < $GoodsTypeCount ; $i++)
{
    $tpl->setVariable("Type",$GoodsTypeArray[$i]); //货物种类

    //指定里层block 名称
    $tpl->setCurrentBlock("GoodsListOfSomeType");

    $GoodsNameArrayCount = count( $GoodsNameArray[$i] );

    //对里层block 进行循环
    for($j = 0; $j < $GoodsNameArrayCount; $j++ )
    {
        //替换HTML 文件中的 tag
        $tpl->setVariable(array ("GoodsName" =>$GoodsNameArray[$i][$j],
        "Price" => $GoodsPriceArray[$i][$j]));
        $tpl->parseCurrentBlock(); //这里也可以写 $tpl->parse("GoodsListOfSomeType");
    }
    $tpl->parse("GoodsList"); //结束外层 block
}

//输出替换后的 HTML
$tpl->show();
?> 

     运行以后可以看到多重循环替换的效果。这样写好后, GoodsList.htm 仍然可以使用网页编辑器如 Dreamweaver、FrontPage 进行编辑, GoodsList.php中是纯粹的PHP代码,不含HTML,方便以后的代码修改和维护。

你可能感兴趣的:(html,编程,PHP,database,include,Dreamweaver)