[PHP]MVC架构模式分析与设计
前言:
文章将介绍通过自己搭建一个MVC微型框架来了解MVC(model-view-control)三层的架构以及关系
MVC(Model-View-Control)三层介绍
为了更好地将各个功能层区分开发以便于不同专长的人各司其职,于是在众多开发者的努力下,以MVC为架构模式的框架越来越多,国内著名的PHP框架有Yii2,Yii以及ThinkPHP等国外的著名PHP框架Laravel等这些框架都是基于MVC模式开发的
简单地说 View是表现层,诸如一些html格式,xml格式等都可以充当该表现层的模板,Model是模型层,诸如一些具体的业务逻辑等都是在model中完成的。而Controller是控制器层,由它进行选择哪个模型以及哪个表现层,打个比方,控制器就像是遥控器而View就像是电视屏幕,而Model就像是电视节目,当然了,比方有些不太合适的地方
MVC工作流程
第一步 浏览者 -> 调用控制器,对它发出指令
第二步 控制器 -> 按指令选取一个合适的模型
第三步 模型 -> 按控制器指令取相应数据
第四步 控制器 -> 按指令选取相应的视图
第五步 视图 -> 把第三步取到的数据按用户想要的样子显示出来
该微型MVC框架组建简介
整个MVC包括两个文件夹和两个文件,分别是一个类库(libs),一个函数库(function),一个启动引擎(pc.php)以及一个require文件
该微型MVC框架的具体实现
function文件夹
该文件夹下存放了一些函数,这些函数的规模不能直接组成一个类库,只能封装成函数,不能封装成类。例如包括了一些简单调用及实例化控制器,模型,视图 的方法 (区别于Mysql类 因为 Mysql对应了一系列操作故能封装成类 )
注意在写这三个的方法时,控制器方法可以有两个参数,模型和视图对应的只能有一个参数 坑处
Mysql一系列操作之所以能封装成一个类,因为他们的一系列操作对应的是一个对象,而把 简单调用及实例化控制器,模型,视图的方法整合在一起写成一个类的话,他们的对象不能唯一,所以不能把 简单调用及实例化控制器,模型,视图的方法整合在一起写成一个类
libs文件夹
这个微型框架的库文件中包括了
-
核心库
能够直接调用,必然要用于实际开发的类文件例如:
1.数据库类(注意这里的数据库类和数据库库是不同的,数据库库里面存储的是具体的某一种数据库的具体操作方法,而数据库类的两个参数之一就是数据库类型也就是数据库库中的其中一个,简而言之就是用数据库类来操作具体的数据库)
2.视图类(这个类是用来初始化和调用View层的对象,在这里的这个框架中应该传入给这个类初始化方法的参数的是Smaty和Smarty的配置文件)
-
数据库库
用于存储各种数据库如mysql,mysqli,pdo等一系列具体操作(指的是增删改查)的代码
-
视图库
这里直接使用了Smarty第三方类库,Smarty是一个视图引擎,引擎具体体现在Smarty中的display方法,可以将模板文件(也可以是html文件)进行编译将其在视图层显示出来
include.list.php
pc.php
pc.php是一个启动引擎程序,这个程序中分别对数据库类,视图类进行了初始化,并且对controller和method静态变量进行了初始化,通过这两个静态变量实例化了一个控制器并调用了控制器,相当于MVC工作流程中的第一步调用控制器,并对它发出指令