code与html分离,PHP中模板的使用

来源:互联网 发布:香港买西服 知乎 编辑:程序博客网 时间:2024/06/08 08:58

转自:http://bbs.blueidea.com/thread-2717864-1-1.html

写了一个简单的练习了下,使代码不再陷入烦人的HTML中,看着干净多了^_^

数据库结构:
其实也就一个表,你可以根据你的需要来设置字段,数据库名:lolooo,表名:wuleying(其实有没有数据库都可以完成我这个例子,不过数据库是为了以后扩展所做,在想加什么功能ING)我这里简单的设了6个字段,分别是:


  1. name   varchar  30
  2. sex    varchar  2
  3. age    int      10
  4. qq     int      10 
  5. email  varchar  50
  6. info   varchar  255
复制代码


然后是模板页了(也就是纯html)
page1.html

    提示:您可以先修改部分代码再运行



page2

    提示:您可以先修改部分代码再运行



花括号里的内容就是要替换掉的,其实用别的符号也行,甚至不用符号都成(当然有可能会出错),不过用花括号比较普遍吧~

P.S.这两个页面我随便排了下版,很粗糙-_!!

然后是关键的了

function.php

  1. <?php
  2. //账号与密码设定
  3. $host = 'localhost';
  4. $user = 'root';
  5. $pass = '';
  6. $database = 'lolooo';


  7. //sql查询A(用于insert update delete)
  8. function sql_a($query)
  9. {
  10.         global $host,$user,$pass,$database;

  11.         $conn = @mysql_connect($host,$user,$pass);
  12.         @mysql_select_db($database,$conn);
  13.         $result = @mysql_query($query);

  14.         return $result;
  15. }

  16. //sql查询B(用于select)
  17. function sql_b($query)
  18. {
  19.         global $host,$user,$pass,$database;
  20.         
  21.         $conn = @mysql_connect($host,$user,$pass);
  22.         $result = @mysql_db_query($database,$query,$conn);
  23.         @mysql_data_seek($result,0);
  24.         while($row = @mysql_fetch_array($result))
  25.         {
  26.                 $output[] = $row;
  27.         }

  28.         @mysql_free_result($result);
  29.         @mysql_close($conn);

  30.         return $output;
  31. }


  32. //sql查询C(用于insert 且自动产生编号)
  33. function sql_c($query)
  34. {
  35.         global $host,$user,$pass,$database;
  36.         
  37.         $conn = @mysql_connect($host,$user,$pass);
  38.         @mysql_select_db($database,$conn);
  39.         $result = @mysql_query($query);
  40.         $result = @mysql_insert_id();
  41.         @mysql_close($conn);

  42.         return $result;
  43. }


  44. //解析网页,并且替换输出
  45. //$parser_array格式为:$array['key'] = value;
  46. function read_and_parser($filename,$parser_array)
  47. {
  48.         $handle = fopen($filename,'r');
  49.         $buffer = fread($handle,filesize($filename));
  50.         @fclose($buffer);

  51.         //开始查找替换
  52.         while(list($key,$value)=each($parser_array))
  53.         {
  54.                 $buffer = str_replace($key,$value,$buffer);//这一句是重点,把指定内容替换
  55.         }
  56.         
  57.         return $buffer;
  58. }

  59. ?>
复制代码



show.php

  1. <?php
  2. include_once('function.php');

  3. $sql = "select * from wuleying";

  4. $row = sql_b($sql);//执行查询

  5. if($_GET['style']==1)
  6. {
  7.         $page = 'page1.html';
  8. }
  9. else
  10. {
  11.         $page = 'page2.html';
  12. }

  13. //把从数据库里取出的数据存到$array这个数组里
  14. $array['{name}'] = $row[0][0];
  15. $array['{sex}'] = $row[0][1];
  16. $array['{age}'] = $row[0][2];
  17. $array['{qq}'] = $row[0][3];
  18. $array['{email}'] = $row[0][4];
  19. $array['{info}'] = $row[0][5];

  20. $output = read_and_parser($page,$array);//用自定义函数替换内容

  21. echo $output;//显示页面

  22. ?>
复制代码




OK,这就是最最最简单的模板套用(精简到不能再精简了),就是什么表现层与逻辑层分离吧(偶概念不清-_!!面壁去)

0 0
原创粉丝点击