MVC核心思想,5步骤
/*
* 第一步 浏览器-》调用控制器,对他发出指令* 第二步 控制器-》按指令选取一个合适的模型
* 第三部 模型-》 按控制器指令取相应的数据
* 第四步 控制器-》 按指令选区相应的视图
* 第五步 视图 -》 把第三步渠道的数据按用户想要的样子显示出来
*/
例子:博客系统
1、浏览器request 调用控制器
2、控制器new model();
model = new Model();
$page = empty($_GET['page'])?1:$_GET['page'];
$data = $model->fetchArticleListByPage(6,$page);
$view_data['article_list'] = $data['DataList'];
$view_data['page'] = $page;
$view_data['count_page'] = $data['Count_page'];
3、model执行sql语句,获取数据
class Model{
protected $db;
public function __construct()
{
$this->db = new PDO( 'mysql:dbname=blog;host=127.0.0.1', 'root', '123456');
}
/**
* 分页获取文章数据
* @param int $number 每页显示多少条
* @param int $current 当前页码
* @return array
*/
public function fetchArticleListByPage($number, $current = 1){
$sql = 'SELECT COUNT(*) AS COUNT FROM Table_content';
$count = $this->db->query($sql)->fetch();
$count = (int)$count['COUNT'];
$count_page = ceil($count/$number);
$start = $number*((int)$current - 1);
$sql = 'SELECT ID,CreateTime,Clicks,Title FROM Table_content LIMIT '.$start.','.$number;
$result['DataList'] = $this->db->query($sql)->fetchAll();
$result['Count_page']=$count_page;
$result['Total'] = $count;
return $result;
}
}
4、控制器选择视图:
switch (date('m-d')){
case '01-01':
display_view('spring', $view_data);
break;
case '12-25':
display_view('chrismas', $view_data);
break;
default:
display_view('default', $view_data);
}
5、视图结合数据输出
{foreach $article_list as $value}
<tr>
<td>{$value['ID'] }</td>
<td><a href="content.php?id={$value.ID}">{$value.Title}</a></td>
<td>{$value.CreateTime}</td>
<td>{$value.Clicks}</td>
</tr>
{/foreach}