国外主流PHP框架比较 [转]


最近简单的使用了目前在国内用的比较多的几个主流国外PHP框架(不包括国内框架),大致对这些框架有个直观上的感受,简单分享一下,对于哪些做框架选型的时候,权当一个参考。
主要参考的框架包括:CodeIgniter、CakePHP、ZendFramework、 Symfony

说明:我对很多框架也没有认真使用,只是简单试用了一下,可能很多看法不成熟或者是错误的,请大家指正,一起成长。 🙂
[separator]

【 CodeIgniter 】

官方网站:http://codeigniter.com
中文网站:http: //codeigniter.org.cn
中文手册:http://codeigniter.org.cn /user_guide
视频教程:http://codeigniter.org.cn/tutorials

测试版本:CodeIgniter_1.6.1

优点:
1. 配置简单,全部的配置使用PHP脚本来配置,执行效率高;具有基本的路由功能,能够进行一定程度的路由;具有初步的Layout功能,能够制作一定程度的界面外观;数据库层封装的不错,具有基本的MVC功能
2. 快速简洁,代码不多,执行性能高,框架简单,容易上手,学习成本低,文档详细;自带了很多简单好用的library,框架适合小型应用

缺点:
1. 把Model层简单的理解为数据库操作
2. 框架略显简单,只能够满足小型应用,略微不太能够满足中型应用需要

评价:
总体来说,拿CodeIgniter来完成简单快速的应用还是值得,同时能够构造一定程度的layout,便于模板的复用,数据操作层来说封装的不错,并且 CodeIgniter没有使用很多太复杂的设计模式,执行性能和代码可读性上都不错。至于附加的 library 也还不错,简洁高效。

【 CakePHP 】

官方网站:http://www.cakephp.org
中文手册:http: //www.1x3x.net/cakephp
视频教程:http: //search.you.video.sina.com.cn/s?key=cakephp
测试版本:cake_1.1.19.6305

优点:
1. CakePHP是最类似于RoR的框架,包括设计方式,数据库操作的Active Record方式;设计层面很优雅,没有自带多余的 library,所有的功能都是纯粹的框架,执行效率还不错;数据库层的 hasOne, hasMany 功能很强大,对于复杂业务处理比较合适;路由功能,配置功能还不错;自动构建脚手架(scaffold)很强大;适合中型应用;基本实现过了MVC每一层;具有自动操作命令行脚本功能;
2. 文档比较全,在国内推广的比较成功,大部分都知道CakePHP,学习成本中等

缺点:<br />1. CakePHP非常严重的问题是把Model理解为数据库层操作,严重影响了除了数据库之外的操作能力
2. CakePHP的cache功能略显薄弱,配置功能稍嫌弱;CakePHP不适合大型应用,只适合中型应用,小型应用来说略微的学习成本高了点

评价:
总体来说CakePHP框架代表了PHP框架很重要的一个时代和代表,并且目前发挥着很重要的作用,不少自己写的框架都模仿了CakePHP的方式,是个里程碑式的产品;CakePHP透露着RoR的敏捷开发方式和把数据库操作认为是唯一Model的设计思想,作为开发快速应用和原型是绝好的工具;同样,

【 Zend Framework 】

官方网站:http://framework.zend.com
中文手册:http://www.phpeye.com/zf
视频教程:http://framework.zend.com/docs /screencasts
测试版本:ZendFramework-1.5.0

优点:
1. 官方出品,自带了非常多的 library,框架本身使用了很多设计模式来编写,架构上很优雅,执行效率中等;MVC设计中,比较简洁,具有路由功能,配置文件比较强大(能够处理 XML和php INI),各种 library 很强大,是所有PHP框架中各种功能最全面的,包括它不仅是一个框架,更是一个大类库(取代PEAR),这是它的主要特色;能够直观的支持除数据库操作之外的Model层(比 CodeIgniter 和 CakePHP 强),并且能够很轻易的使用Loader功能加载其他新增加的Class;Cache功能很强大,从前端Cache到后端Cache都支持,后端 Cache支持Memcache、APC、SQLite、文件等等方式;数据库操作功能很强大,支持各种驱动(适配器)
2. 文档很全,在国内社区很成熟,并且目前不少Web 2.0网站在使用,学习成本中等

缺点:
1. MVC功能完成比较弱,View层简单实现(跟没实现一样),无法很强大的控制前端页面
2. 没有自动化脚本,创建一个应用,包括入口文件,全部必须自己手工构建,入门成本高
3. Zend Framework 作为一个中型应用框架问题不大,也能够勉强作为大型应用的框架,但是作为一个很成熟的大型PHP框架来说,还需要一些努力

评价:
作为官方出品的框架,Zend Framework的野心是可以预见的,想把其他框架挤走,同时封装很多强大的类库,能够提供一站式的框架服务,并且他们的开发团队很强大,完全足够有能力开发很强大的产品出来,所以基本可以确定的是Zend Framework前途无量,如果花费更多的时间去完善框架。同样的,Zend Framework架构本身也是比较优雅的,说明Zend官方是有很多高手的,设计理念上比较先进,虽然有一些功能实现的不够完善,比如View层,自动化脚本等等,这些都有赖于未来的升级。总体来说Zend Framework是最值得期待的框架,当然,你目前要投入你的项目中使用也是完全没问题的。

【 Symfony 】

官方网站:http://www.symfony-project.org
中文网站:http://symfony-project.cn
权威指南:http://www.symfony- project.org/book
学习参考:http://sf.thecodecentral.com
测试版本:symfony-1.0.13

优点:
1. Symfony 是我了解的PHP框架中功能最强大的,而且我使用时间比较长,但是很多功能还是没有挖掘出来;它完整实现了MVC三层,封装了所有东西,包括 $_POST,$_GET 数据,异常处理,调试功能,数据检测;包含强大的缓存功能,自动加载Class(这个功能很爽),强大的i18n国家化支持;具有很强大的view层操作,能够零碎的包含单个多个文件;非常强大的配置功能,使用yml配置能够控制所有框架和程序运行行为,强大到让人无语;能够很随意的定义各种自己的 class,并且symfony能够自动加载(auto load)这些class,能够在程序中随意调用;包含强大的多层级项目和应用管理:Project –> Application –> Module –> Action,能够满足一个项目下多个应用的需要,并且每层可以定义自己的类库,配置文件,layout;非常强大的命令行操作功能,
包括建立项目、建立应用、建立模块、刷新缓存等等;
2. Symfony绝对是开发大型复杂项目的首选,因为使用了Symfony,将大大节约开发成本,并且多人协作的时候,不会出现问题,在Project级别定义好基础Class以后,任何模块都能够重用,大大复用代码

缺点:
1. 数据库操作model采用了重量级的propel和creole,不过在我测试的版本中已经把他们移到了addon里,可用可不用
2. 缓存功能无法控制,每次开发调试总是缓存,需要执行 symfony cc, symfony rc 来清除和重建缓存;
3. 效率不是很高,特别是解析模板和读取配置文件的过程,花费时间不少;
4. 学习成本很高,并且国内没有成熟的社区和文档,连中文手册都没有,相应的要掌握所有功能,需要花费比较多的时间
评价:
Symfony绝对是企业级的框架,唯一能够貌似能够跟Java领域哪些强悍框架抗衡的东西;强悍的东西,自然学习复杂,但是相应的对项目开发也比较有帮助,自然是推荐复杂的项目使用Symfony来处理,觉得是值得,后期的维护成本比较低,复用性很强。相应的如果使用Symfony的应该都是比较复杂的互联网项目,那么相应的就要考虑关于数据库分布的问题,那么就需要抛弃Symfony自带的数据库操作层,需要自己定义,当然了,Symfony支持随意的构造model层。

【 总评】

以上数款框架,各有特色,而且都是开源项目,不过框架针对的项目不一样,一般来说 CodeIngiter 比较适合小型项目,CakePHP 和 Zend Framework 比较适合中型项目,Symfony  比较适合大型重量级项目,在项目选型的时候,要充分考虑框架的可以定制性、扩展性,因为每个项目都无法确定你是否会随着需求的变化进行改变。

相对来说,Zend Framework 和 Symfony 应对变化的能力比较强,特别是能够随意定制 model 层的Class,能够非常方便增加自己业务或者数据处理类,我是个人比较推荐在中大型项目中使用的框架。CodeIngiter 和 CakePHP 在中小型项目中同样能够发挥重大作用,快速开发和原型构建,非常适合目标不清晰的原型项目的开发。了解一个框架最好的方式就是使用它,学习它最好的方式就是看视频。:-)

仁者见仁,智者见智,在项目挑选框架的时候,请先认真考察项目的需求和未来的变化,然后选择合适的框架,让项目开发速度和后期维护性得到一个合理的平衡,当然了,也许,自己写一个框架更适合。 🙂

泛泛的评价了几款框架,估计很多东西都没有说到点子上,大家就姑且看之,同样欢迎提出看法指正!

提高网站转化率的10个细节


流量问题解决后,紧接着的问题”转化率”出现了.这也是让很多购物赢利性网站站长头疼的问题,因为转化率的问题直接关系到金钱的问题.以下是我从网络上截取整理的两个提高网站转化率的版本,一个是从网站结构内容等SEO角度出发,一个是从用户体验的角度出发.
从网站结构内容等角度出发:

(1)调整大字标题的第一个词组。在每个加粗或大字标题的第一个词组比其它位置的词组对用户的刺激和影响会大很多,看看你网页每个标题的第一个词组,还有没有比它更有影响力的词组可以打动用户呢?有些标题的重点关键字在短句的较后位置,可以通过调整句子的表达方法把有影响力的关键字提前,这有利于“震撼”用户从而提高网站转化率。

(2)重复重要关键字。比如在你大标题里的重要关键字应该在正文的不同段落中重复出现几次,这不仅可以提高关键字密度有利于搜索引擎排名,而且更重要的是可以刺激用户提高网站转化率。不要假设你的潜在用户会从头到尾每一句都认真地阅读,要假设用户是跳跃性地快速浏览你的文章,眼球每次停留只能收到25%的信息量,保证高相关性的关键字可以在用户眼球每次停顿时都可以看到。

(3)减少选项。在需要用户转化的着陆页中,减少用户可选择点击的选项,减少用户对内容选择作决定,尽量减化流程。如果确实需要提供第二个选项,可将它放在网页的下端位置,防止用户从注册界面中分散注意力,因此通过减少干扰选项来提高网站的转化率。

(4)“·”标明重点项目符号是很有用的。在描述网站给用户带来的好处时,用“·”将重点内容标出的效果和一大段文字是很不同的,将一段文字拆成几句简短有力的小句并用“·”标出,效果不容小视。

(5)增加号召性动词。比如说“马上注册”“点击这里快速注册”等带有动词的号召性语句。最好在这句话前加一个为用户带来某好处的精练句子。最好的办法就是对着陆页的不同的广告文案和设计布局进行小规模测试后再大规模宣传。

从用户体验的角度出发:

提高网站客户转化率的措施之一:证明

让更多顾客购买,有一个看似非常简单、却被很多网站忽略的因素:社会证明。人们往往会因为其它人都购买了某商品而认为这个商品值得购买,因此网站上增加“热销商品”(Best Sellers) 或 “推荐商品”(Recommended Items),这为顾客节省了购买考虑的时间,同时,增加更多来自第三方的肯定性反馈,如顾客的反馈信息,奖励及赞誉,商品/服务评论,案例/成功故事等等。

提高网站客户转化率的措施之二:优惠

基于网站的有效促销方式有:免费试用、下载、在线工具、视频演示等。基于价格的促销办法主要有免运费、打折、现金回馈等。XXX.com网站上,我们采用定期抽奖获得数码相机的办法鼓励顾客注册我们的促销Email,这个策略非常成功。

提高网站客户转化率的措施之三:安全

安全是网民实施网上购物的最基本需求。我们尽量在消费者实施网上购买、结算、配送的全过程中都突出显示我们的行业及安全证明、承诺及保证。

提高网站客户转化率的措施之四:沟通

网站上增加让消费者与销售代表或客服人员互动的机会很重要。虽然我们不可能象亚马逊那样在网站上整合诸如“点击对话”的按钮,但在 XXX.com网站上,我使用了一个在线调查表单,了解顾客对于网站的看法,他们希望怎么改进,希望收到什么样的Email订阅信息等。在不到一周的时间收到500份左右的反馈意见,这些客户反馈意见对于我们的Email营销开展和网站改进有很大帮助。

提高网站客户转化率的措施之五:监测

我们通过流量统计系统每天监测网站的访问量来源、搜索引擎及关键词统计,尤其 google的流量统计工具将adwords关键词广告和网站流量分析都整合在一起。根据对这些数据的分析,我们获得了不断优化改进网站的依据。

开发工具大比拼之Visual C++ VS Delphi


引言
"Visual C++与Delphi之比较"最近在CSDN的论坛上的讨论非常火热,本文将以一个程序员的角度,从技术水平、功能、性能、易用性、稳定性、发展历程和前景等方面,以Visual C++6和Delphi5为代表,尽可能客观地比较介绍Visual C++和Delphi这两大主流开发工具的优缺点,其中将涉及到语言、应用框架、控件、编译和连接、集成界面、调试、COM、数据库开发等。本文还将对如何选择使用这两个开发工具提出一些建议。
值得一提的是,由于C++Builder与Delphi同为Inprise公司产品,它们除了使用的语言不同,其余特性几乎都相同。因此本文对C++Builder程序员和学习者也有参考价值。

继续阅读“开发工具大比拼之Visual C++ VS Delphi”