动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
  
   PHP → 阅读文章

 PHP:MVC迷思

作者来源: 
阅读 1610 人次 , 2006-3-29 4:12:00 


近来设计模式风行,mvc随处可见,php领域也不例外,很多论坛都开始讨论在php中使用mvc。然而,m、v、c在php中到底该如何实现?mvc真的适合php么?这里easy给出一些自己的思考。


mvc的原型

mvc本来是存在于desktop程序中的,m是指数据模型,v是指用户界面,c则是控制器。使用mvc的目的是将m和v的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据你可以分别用柱状图、饼图来表示。c存在的目的则是确保m和v的同步,一旦m改变,v应该同步更新。


java中的mvc

java把mvc引入了web领域,并在此基础上架构出了一套称为model2的体系。由于web的特殊性,java中的mvc和desktop中的mvc并不完全一致。主要原因是web中的v不是持续的,用户每访问一次,v就要重新生成一次,所以v始终是和m一致的,不需要c来控制同步。那么java中的c在干什么?java中的c通常用于流程的转向,其实用的是dispatch模式,不再是desktop中的c了。



php中的mvc

要在php中原封不动的copy java的mvc是不可能的。问题主要表现在m上,在java中,m是独立于业务逻辑和表现逻辑的数据模型,在服务器端跨页面存在,java bean扮演的就是这个脚色。而php进程并不长时间驻留于内存,只在php页面开始执行时创建,在页面解释执行结束时就已经结束。在这样的情况下,我们根本无法直接实现m。所以所有声称实现了mvc模式的php程式都只能通过模拟手段来实现m。实现的方式一般是在当前页面结束前把数据存入数据库或者cookie/session,在下一个页面中再透过数据库或者cookie/session重建m。这样的方式和java中的bean比起来可以说是开销巨大,本来往内存中写数据的简单操作现在要从服务器端传到客户端或者数据库,然后再传回来。与其用这么大的开销来维护一个数据模型再在最后把这个模型塞回数据库,还不如直接根据需要更新数据库里边的数据。

现在php中的mvc架构可以用下图来表示。





然后我们再来看v。现在很多php程序简单的使用了一些模板技术就在说明中写“采用mvc架构”。其实绝大多数的php模板程序都只是分离html和php的,而非mvc强调的显示逻辑和业务逻辑分离。一个混用html和php的页面一样可以是mvc的一部份。如何分离显示逻辑和业务逻辑至今没有一个满意的方案。我个人则比较认同http://www.phpe.net/articles/384.shtml的实现方案。至于c,和java中差不多,还是被用作转向,这个在php中其实并不重要。


一个极耗资源的m + 一个区别不大的v + 可有可无的c 构成了php中所谓的mvc。

基于以上分析,easy认为,php原有的3层构架比所谓的mvc更为高效,而3层构架中的表现层要解决的问题mvc中的v也同样存在。一个改进后的3层架构比mvc更适用于php。

ps:有的方案把业务逻辑并入m中(http://www.phpe.net/articles/382.shtml),这其实是mvc的思想背道而驰的。

 
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:PHP and UML Class Diagrams
· 下一篇:用正确的小汽车对象学习和熟悉类的概念
· 如何使用PHP中的正则表达式
· 正则表达式系统教程(五)
· PHP 编码规范(23)
· 用正确的小汽车对象学习和熟悉类的概念
· Windows 98下安装Apache(PWS) PHP4 MySQL phpMyAdmin的方法


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077