模型视图控制器-php模板,用于不同css和mysql的不同页面


model view controller - php template for different pages with different css and mysql

嗨,我正试图弄清楚如何用一个类来创建PHP模板系统,我不喜欢header.PHP footer.PHP或smarty或任何blablabla,只想要template.html、class.PHP和page1.PHP、page2.PHP等…用我自己的PHP代码,我发现很多网站上都有人教我如何做到这一点,但我仍然有很多问题。

1) 我想添加额外的css到一些页面

2) 有些页面有php代码,比如mysql查询和类似的东西

3) CONTENT是一个变量,我希望它在模板中不仅仅是单词,而是大量的div和其他东西,而且在一些页面中,CONTENT变量内部有查询,比如填写(例如)下拉菜单。

希望有人能指导我,我实际上有我的时间来解释,(标签只是随机的)

<!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 content="text/html; charset=utf-8" http-equiv="Content-Type" />
<meta http-equiv="X-UA-Compatible" content="IE=8" />
<title>CompanyName | ##TITLE##</title>
<link href="layout.css" rel="stylesheet" type="text/css" />
<link href="styles.css" rel="stylesheet" type="text/css" />
##EXTRA_CSS##
<link rel="shortcut icon" href="/favicon.ico" />
<!--[if IE 6]>
    <script src="DD_belatedPNG_0.0.8a-min.js"></script>
    <script>
            DD_belatedPNG.fix('img, div');
    </script>
<![endif]--> 
##EXTA_JS##
</head>
<body>
    <div id="main">  
        <div id="container_black">
            <div id="container_white">
                <div id="container_header">
                    <div id="logo_top"></div>           
                    <div id="lineas_verticales_top">
                        <div class="volver_portada"><a href="index.shtml">Volver a portada</a></div>
                        <div class="english_spanish"><u>Español</u> | <a href="../en/index.shtml" class="english_spanish">English</a></div>
                    </div>
                    <div id="nav_bar_black"><div id="nav_bar_red"><div id="nav_bar_yel">
                        <ul class="menuholder"> 
                            <li class="menu_principal"><a href="#" title="Principal">Principal</a></li> 
                            <li class="menu_empresa"><a href="#" title="Empresa">Empresa</a></li> 
                            <li class="menu_productos"><a href="#" title="Productos">Productos</a></li> 
                            <li class="menu_clientes"><a href="#" title="Clientes">Clientes</a></li> 
                            <li class="menu_recetas"><a href="#" title="Recetas">Recetas</a></li> 
                            <li class="menu_contacto"><a href="#" title="Contacto">Contacto</a></li> 
                        </ul> 
                    </div></div></div>
                    <div id="topbg_degr"></div>
                </div>
                <div id="container_left">
                    <div id="conmargen_left_top"></div>
                    <div id="container_conmargen_left_middle">
                        ##CONTENT##
                    </div>
                    <div id="conmargen_left_bottom"></div>
                    <!--[IF INDEX]
                    <div id="fono"></div>
                    <div id="dir"></div>
                    -->
                </div>
                <!--[IF INDEX]
                <div id="nav"></div>
                -->
                <div id="container_right">
                    <div id="conmargen_right_top"></div>
                    <div id="container_conmargen_right_middle">
                        <!--[IF PAGE OR PAGE OR PAGE]
                        <a href="#" id="recetas_poster" title="recetas"></a>
                        [ELSE IF]
                        <a href="#" id="clientes_poster" title="recetas"></a>
                        [ELSE IF]
                        <a href="#" id="productos_poster" title="recetas"></a>
                        -->
                    </div>
                    <div id="conmargen_right_bottom"></div>
                </div>
                <!--[IF INDEX]
                <div id="frame_facebook">
                <a href="#" class="facebook" title="CompanyName"><span>CompanyName</span> en Facebook</a>
                <div class="breakL"></div>
                <fb:like href="#" layout="button_count" show_faces="true" width="100" font="tahoma"></fb:like>
                </div>
                -->
                <br/>   
            </div> <!-- cierre del container white -->
        </div> <!-- cierre del container black -->
        <div id="footer">   
                <div class="footer_comment">
                    CompanyName Todos los derechos reservados 2011
                </div>
        </div>
    </div> <!-- cierre del main -->
<br/>
</body>
</html>

例如contact.php,内容将是一个表单,在页面的顶部,我有一个巨大的php代码,我在其中进行验证。

如果有人能让我走上正确的道路,我将不胜感激。提前谢谢。

可能有一百种不同的方法可以实现这一点,每种方法都有各自的优缺点-如您所说,使用数据库和/或ajax调用和/或页眉和页脚。你真的必须找出哪种方式最适合你的特定项目或编码风格,或者两者兼而有之。

然而,如果你真的只想要"template.html",但有一些页面包含PHP、javascript、MySQL或其他任何东西,那么我建议你这样做。

使用占位符创建template.html,如{PAGE_TITLE}、{MAIN_CONTENT}或您需要的任何内容。

创建page1.php/page2.php等,并进行任何服务器端工作,生成与占位符匹配的变量。将它们存储为数组可能很方便,例如:

PAGE_VARS array( 
                 ['TITLE'] => My Page
                 ['CONTENT'] => This is my page content
               )

在"page"脚本结束时,将template.html的全部内容加载到字符串中

$template = file_get_contents('template.html')

然后,使用一个基本循环:,用替换的变量构建模板

foreach ($PAGE_VARS as $KEY=>$VALUE) {       
   $template = str_replace("{".$KEY."}",$VALUE,$template)
}

(使用上面的一些正则表达式可以变得更聪明,可能更高效,这只是一个快速的例子。)

输出您的模板。

echo $template;

您可以创建一个像这样的快速类(class.php),它将成为您的"模板引擎":

class Template {
    var $contents;
    function load($file) {
        if ($fp = fopen($file, "r")) {
            $this->contents = fread($fp, filesize($file));
            fclose($fp);
        }
    }
    function replace($str,$var) {
        $this->contents = str_replace("<".$str.">",$var,$this->contents);
    }
    function show() {
        $search = array(
                '/'t/', //Remove Tabs
                '/<!--[^'[-]+?-->/', //Remove Comments
                '/'n'n/' //Remove empty lines
                );
            $replace = array(
                '',
                '',
                ''
                );
        $this->contents = preg_replace($search, $replace, $this->contents);
        echo $this->contents;
    }
}

在template.html文件中,在要放置内容的位置添加特殊标记,如下所示:

<html><head></head>
<body>
<div id="id1"><page_title></div>
</body>
</html>

然后创建一个函数在标签内写入(每个区域一个):

function writetitle($s) {
    $GLOBALS['writes']++;
    $GLOBALS['page_title'] .= $s;
    return;
}

最后,在page.php中,调用类,编写内容,并生成页面:

require_once('class.php');
//Load Class
$template = new Template;
$template->load("template.html");
//Some query :
$query = mysql_query('SELECT...');
$res = mysql_num_rows($query);
//write your content :
writetitle('my title, '.$res.'');
//Generate the page :
$template->show();

这样可以创建任意数量的分区writetitle的行为类似于echo,因此您可以进行查询和所需的一切。

我希望它能有所帮助。

我建议使用PHP而不是自己的伪代码来编写模板。

写是完全有效的

...
<body>
<?php if($fooBar == "hahahaha"):?>
  <a href="www.foobar.com">The cool foobar link</a>
<?php endif;?>
</body>
...

然后我会创建一个包含所有常见html等的layout文件。然后使用小模板片段插入到主要内容所在的布局中。通过在模板中包含实际的PHP代码,PHP工程师可以处理它们,并且您不必编写自己的逻辑来处理循环、if语句等。

看看Zend Framework,你会对如何编写模板引擎有一个很好的想法。