ZF等常用php框架中存在的问题


Posted in PHP onJanuary 10, 2008

从Zend Framework v0.13版本开始,我就开始学习使用Zend Framework。当时公司的一个项目也恰好用到了Zend Framework。到了0.6的版本之后就再没有关注细节了。前些日子听说Zend 公司将在5月份正式推出Zend Framework,今天特意叫同学下载下来测试。

  最新版本是0.93的,测试发现Zf框架越来越傻瓜式了。很多东西都直接封装在ZF的library里面。你只要知道如何调用就OK拉。和之前的版本详细的确有比较大的变化,也增加了比较多功能。
  首先,Zend.php不见了,取而代之的是一个Zend_load类,放在load.php里面。
  第二、库类的加载更加方便了。之前的ZF要在子目录下使用是比较麻烦的。现在可以直接在子目录下使用,而且现在也可以不通过mod_rewrite来使用,可以通过http://path/to/site/controller/action来访问,类似我在《回答PHPCHINA上的几个问题:URL映射 》谈到的URL映射。
  第三、把试图直接集成到了Controller里面,方便调用。不过有个不好的地方就是要按照ZF的要求来规范程序的目录结构。
  另外还增加了很多功能,比如说访问控制等等。总之,变化很大。今天晚上我也只是大概的看了下。

  对于ZF,cakephp等等框架,我觉得大家在学习的时候最好能明白框架的基本原理,所谓“万变不离其中”。框架本身就是很简单,完全没有ZF等之类这样复杂,它们只是把细节处理很完善,同时要做到通用,规范、功能强大,所以就复杂了。关于框架的基本原理,我推荐大家上phpit.net上看一篇文章,关于如何使用PHP5搭建一个简单的MVC框架的(在喜悦国际村上有翻译),或者可以看看我的几篇文章《PHP实现MVC开发得最简单的方法》系列文章。

  之前在chinaunix上有一个帖子,讨论在PHP项目中使用对象和过程的优势和不足,讨论的非常不错。有支持对象的,也有认为非对象的开发更加符合WEB开发的特点,有更好的性能。
  我个人是非常支持对象式开发的,尤其在PHP5环境中(因为PHP5的对象和PHP4的对象完全不是一回事,这个看看Zend 引擎就知道了)。但是帖子中说到的几点也很有道理:比如“OOP的形式却无故要装入很多无关的函数”。WEB开发是非常强调性能的,而PHP是一种解释性语言,如果include过多的代码是很影响性能的。这个问题在Zend Framework,CackePHP,Fleaphp和我的框架PHPbean中都存在。

  比如说一个indexController,这里使用Zend Framework做例子。代码如下:

<? 
class indexController extends Zend_Controller_Action { 

    function init(){ 
        $this->initView(); 
    } 

    function indexAction(){ 
        //echo 'index/index'; 
        $this->view->title='hello World!'; 
        $this->render(); 
    } 

    function testAction(){ 
        echo 'index/test'; 
    } 

    function showAction(){ 
        echo 'index/show'; 
    } 

?> 

    比如说我们访问index/index,那么testAction()和ShowAction()方法的内容就完全是多余的。在实际开发中按照这种思路,一般是一个功能模块对应一个controller,比如说用户就对应一个userController,然后里面有登录、退出、注册、列表、详细显示等等多种方法。当一个项目一大的时候一个controller可能就几K到十几K。那这样的模式就非常的不好。

  在JAVA的struts中,就采用了完全不同的方式,他是一个action对应一个文件。我觉得这是一个很好的参考方法。

  我觉得PHP5的话,使用面对对象更加何时。可以说面对过程能实现的,面对对象都能实现,而且可以实现的更好。但重要的一点是:采用面对对象的思维来使用面对对象,而不是用面对过程的思维来写面对对象的程序! 

PHP 相关文章推荐
如何把PHP转成EXE文件
Oct 09 PHP
PHP控制网页过期时间的代码
Sep 28 PHP
PHP下操作Linux消息队列完成进程间通信的方法
Jul 24 PHP
表格展示无限级分类(PHP版)
Aug 21 PHP
解析MySql与Java的时间类型
Jun 22 PHP
php解决约瑟夫环示例
Apr 09 PHP
PHP数组编码gbk与utf8互相转换的两种方法
Sep 01 PHP
注意!PHP 7中不要做的10件事
Sep 18 PHP
Laravel手动分页实现方法详解
Oct 09 PHP
浅谈PHP中pack、unpack的详细用法
Mar 12 PHP
ThinkPHP实现的rsa非对称加密类示例
May 29 PHP
laravel7学习之无限级分类的最新实现方法
Sep 30 PHP
逐步提升php框架的性能
Jan 10 #PHP
在PHP中使用Sockets 从Usenet中获取文件
Jan 10 #PHP
php扩展ZF――Validate扩展
Jan 10 #PHP
set_include_path在win和linux下的区别
Jan 10 #PHP
php模板之Phpbean的目录结构
Jan 10 #PHP
Phpbean路由转发的php代码
Jan 10 #PHP
php框架Phpbean说明
Jan 10 #PHP
You might like
一个简单的php加密解密函数(动态加密)
2013/06/19 PHP
is_uploaded_file函数引发的不能上传文件问题
2013/10/29 PHP
详谈php ip2long 出现负数的原因及解决方法
2017/04/05 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
2018/06/13 PHP
搭建PhpStorm+PhpStudy开发环境的超详细教程
2020/09/17 PHP
jQuery dialog 异步调用ashx,webservice数据的代码
2010/08/03 Javascript
javascript使用中为什么10..toString()正常而10.toString()出错呢
2013/01/11 Javascript
js里取容器大小、定位、距离等属性搜集整理
2013/08/19 Javascript
SeaJS入门教程系列之SeaJS介绍(一)
2014/03/03 Javascript
使用jQueryMobile实现滑动翻页效果的方法
2015/02/04 Javascript
JavaScript中isPrototypeOf函数作用和使用实例
2015/06/01 Javascript
JS实现仿新浪微博发布内容为空时提示功能代码
2015/08/19 Javascript
javascript日期格式化方法小结
2015/12/17 Javascript
快速学习AngularJs HTTP响应拦截器
2015/12/31 Javascript
最简单的tab切换实例代码
2016/05/13 Javascript
jQuery插件formValidator实现表单验证
2016/05/23 Javascript
jQuery简单实现仿京东分类导航层效果
2016/06/07 Javascript
微信小程序 wx.uploadFile无法上传解决办法
2016/12/14 Javascript
探秘vue-rx 2.0(推荐)
2018/09/21 Javascript
微信小程序实现批量倒计时功能
2020/11/01 Javascript
在vue项目中使用codemirror插件实现代码编辑器功能
2019/08/27 Javascript
layui之数据表格--与后台交互获取数据的方法
2019/09/29 Javascript
python实现多线程暴力破解登陆路由器功能代码分享
2015/01/04 Python
Python挑选文件夹里宽大于300图片的方法
2015/03/05 Python
Python批量修改文本文件内容的方法
2016/04/29 Python
解决python "No module named pip" 的问题
2018/10/13 Python
python面向对象之类属性和类方法案例分析
2019/12/30 Python
容易被忽略的Python内置类型
2020/09/03 Python
设计师家具购买和委托在线市场:Viyet
2016/11/16 全球购物
马德里著名的运动鞋商店:NOIRFONCE
2019/04/12 全球购物
工厂总经理岗位职责
2014/02/07 职场文书
四年级评语大全
2014/04/21 职场文书
四年级学生评语大全
2014/04/21 职场文书
课外活动总结范文
2014/07/09 职场文书
小学教师自我评价
2015/03/04 职场文书
Vue OpenLayer测距功能的实现
2022/04/20 Vue.js