zoukankan      html  css  js  c++  java
  • 简介在PHP中采用MVC分离的设计方法

    为了更好的演示MVC的工作方式,我们使用了一个简单的新闻文章发布系统作为例子.分为使用MVC和不使用MVC两种方式.
    我们只作一个基本的演示,从数据库里读出一些文章列表,并在页面上显示。一般的流程就是,连接数据库,查询数据库,循环输出html结果。下面的代码就是如此做的。(淡水感觉怪怪的,语言组织得不好。好在代码比较容易理解)

    PHP代码
    1. <?php   
    2. mysql_connect(...);   
    3. $result = mysql_query('select * from news order by article_date desc');   
    4. ?>   
    5. <html>   
    6.     <body>   
    7.         <h1>News Articles</h1>         
    8.       <?php while ($row = mysql_fetch_object($result)) { ?>   
    9.                 <h2><?php echo $row->headline ?></h2>              
    10.                 <p>   
    11.                     <?php echo $row->body ?>   
    12.                 </p>   
    13.       <?php } ?>   
    14.     </body>   
    15. </html>  

    采用mvc方式.

    model:

    PHP代码
    1. <?php      
    2. function get_articles()   
    3. {   
    4.     mysql_connect(...);    
    5.     $result = mysql_query('select * from news order by article_date desc');    
    6.     $articles = array();   
    7.     while ($row = mysql_fetch_objects($result)) {   
    8.         $articles[] = $row;    
    9.     }   
    10. return $articles;   
    11. }   
    12. ?>  

    controller:

    PHP代码
    1. <?php   
    2. $articles = get_articles();    
    3. display_template('articles.tpl');   
    4. ?>  

    view:

    PHP代码
    1. <html>   
    2. <body>   
    3. <h1>News Articles</h1>   
    4.         <?php foreach ($articles as $row) { ?>   
    5.         <h2><?php echo $row->headline ?></h2>              
    6.             <p>   
    7.                 <?php echo $row->body ?>   
    8.             </p>           
    9.         <?php } ?>     
    10. </body>   
    11. </html>  

    译得不好请多多包涵.原文:http://reinholdweber.com/?p=16

  • 相关阅读:
    「Poetize7」Freda的访客
    「Poetize8」Divisible
    「Poetize5」Vani和Cl2捉迷藏
    1082. 员工的重要度
    1080. 最大的岛
    1079. 连续子串计数(经典)
    1078. 数组的度
    1071. 词典中最长的单词
    1068. 寻找数组的中心索引
    1062. 洪水填充(经典)
  • 原文地址:https://www.cnblogs.com/kuyuecs/p/1274571.html
Copyright © 2011-2022 走看看