热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PHP框架Laravel还是Codeigniter?

我最近要搞一个项目,项目不是很大,需要一定的后期扩展,关键要考虑的是性能与开发速度。我个人PHP基础还行,只接触过Smarty,对MVC略熟悉,没真正深入学习过一个MVC框架,可以说是一个新手,请大家针对我现在的情况,给我提出些建议或者你对Codeigniter和Laravel的使用心得,多谢!(图片引自对PHP框架性能对比systemsarchitect.netperforma
我最近要搞一个项目,项目不是很大,需要一定的后期扩展,关键要考虑的是性能与开发速度。我个人PHP基础还行,只接触过Smarty,对MVC略熟悉,没真正深入学习过一个MVC框架,可以说是一个新手,请大家针对我现在的情况,给我提出些建议或者你对Codeigniter和Laravel的使用心得,多谢!(图片引自对PHP框架性能对比systemsarchitect.net/pe

回复内容:

力荐Laravel!
顺更新2015最流行PHP框架报告:
更多报告信息:laravelbase.com/posts/3
这两个框架不是同一个级别的。
CI比较接近原生的PHP,在原有PHP代码的基础上封装了很多类,因为它架构简单,所以容易扩展。从另一个角度来看,也就是没啥架构,最最原始的三层架构。
Laravel 简直就是一次创新,大量吸收了Java,RoR等其他框架的精华,在架构方面,已基本做到现有Php框架最佳,扩展性,伸缩性强大得一塌糊涂,非常适合团队作战。

对于新手来说,Laravel初看上去不太像Php的原本写法了,所谓优雅,就是你光凭代码就可以知道意思,而不用读注释,代码精简复用度非常高;Laravel开发人员都是PHP圈子最顶尖的高手,他们习惯用新的技术和架构,即便如此,Laravel其实上手并不难,一旦以你掌握了它的大致要点后,你会逐渐发现它在每一个方面都全面超越CI,且实用性非常高。

Laravel的内核扩展其实也非常方便(这么强大的框架你没事干嘛去扩展内核:D),只不过它少量内核类的耦合度较高,你需要花点时间读读源码和API。如果是自定义类,那就完全没问题,太方便了。

P.S 欢迎大家访问我用Laravel 5 写的小站:LaraBase - PHP工匠之家

说句题外话:Laravel 圈子里面有个奇葩,叫 Jeffery Way,他以前在tutsplus.com当编辑的,就是专门教CI的,后来成为Laravel的死忠,现在专职 教Laravel 的视频课程,他的网站laracast.com可能是这个星球上关于编程方面最强大的教程,那些说Laravel资料少的可以去看看。

什么?英语不行? 我认为为了Laravel你可以去学习一门语言,就是有那么值。 小项目的话 ci 还是很值得推荐的(当然也得看有多小……)。

ci 最大的好处是上手容易,对新手比较友好。有多容易呢?这么说吧,我曾经在完全不会 php 的情况下边学边写,照猫画虎,用 ci 开发了一个个人 podcast 网站,带完整后台。

因为是老项目,ci 的中文资料和案例非常丰富。ci 本身的文档也非常详实,易阅读。横向比较的话,我认为ci 比 nodejs 上的 express 还容易入门。 由衷推荐 Laravel

Laravel是PHP 5.3之后开发的新框架,充分使用了PHP 5.3之后的新特性,不像很多老牌框架有一大堆历史包袱。
官方文档详尽丰富且归类科学,稍微有一点PHP基础便可很快入门,写出可用的示例程序
核心功能大量使用Composer第三方类库,在很多人看来这是Laravel的弊病之一,但我认为这正是其优雅设计哲学之体现。所谓 术业有专攻,专业的人做专业的事, 成熟的第三方类库往往是专业团队经过长时间迭代打磨的成果,比如Laravel大量选用的symfony组件,日志库 monolog,时间库 carbon 都是该类别最稳定流行的库。
我相信,短暂尝试后,很快你便会爱上Laravel,同时会爱上Composer的便捷。

THE PHP FRAMEWORK FOR WEB ARTISANS你,值得拥有。
-------
很赞同 @谢弟 的观点,框架的性能不是不重要,只是没有重要到需要优先考虑的地步,在我很有限的几年WEB开发经验下面,我觉得90%的性能瓶颈都是在数据库层面,PHP层面即便真地出现性能瓶颈,线性地增加PHP处理节点或者使用HHVM这种开源项目也是无痛且高效的办法。

我认为WEB开发多数情况下是敏捷开发,因此选择框架是大致可以考虑以下几点:
1. 开发迅速 : 基础组件齐全且不累赘,框架的设计哲学可以助人快速写出优雅且高效地代码(相对而言)
2. 文档简明丰富和社区活跃 : 文档不是多就好,精心规划的文档内容组织和简明到位的排版可以大量降低框架的学习成本,比单纯的求多求全堆砌内容高明很多。活跃的社区可以确保问题被快速响应,拥有大量工具模块
3. 逻辑清晰 : 框架的代码逻辑清晰,代码的目录结构清晰,轻松地协作开发和代码重用
4. 可扩展和无痛版本更新 : 核心代码低耦合,便于扩展,框架设计有预见性,版本升级无需大功干戈
5. 便于测试 : 一般来说满足了 4 ,测试都不会是大问题,Codeception,phpunit 这种第三方测试工具很多
6. 性能 : 大多数WEB应用无需考虑框架层面的性能问题,当你真的需要考虑框架性能问题的时候,也有很多平滑地解决方案
7. 无重大BUG漏洞:这个当然最重要,不过一般来说成熟的开源框架不会有这个问题,放最后 thinkphp吧,这个简单易用,但是缺点非常明显,在更新26个字母就用完了 首先声明一下PHP框架的性能问题真的不重要, 性能问题主要还是数据库那块.

再说PHP机器是可以线性扩展的, 如并发性能不足以支承当前负载, 可以加机器解决. 而且不用修改任何代码.

理论上能线性扩展的问题都不是问题.

再说下框架吧, CI框架是一个相当简洁的框架, 该有的它都有, 比如input过滤器, url路由, helper等等.

上手相对容易, 不过这些组件是框架的都会有, 再说它确实是老了. 很多思想跟不上时代.

Laravel 比较新, 看下了它的路由, 写的不错, 比ci的路由处理要方便简单. 很多新的思想在这个框架里面

都有体现. 而且Laravel的市场使用率是最高的, 相信大多数人选择它是有理由的.

如果之前没有使用框架的经验, 建议用Laravel.

其次, 使用什么框架不重要, 重要的是你对框架的理解以及对框架的改造能力.

所以一定要看懂框架的源代码, 比如数据库访问层, url路由的原理...

上个图(关于不同框架的市场占有率)

大概读过这两者的代码
CI的设计比较老套,且还有历史包袱
Laravel因为是后来者,设计上更先进一些
我是倾向于Laravel的

先把你这个项目内主要的技术需求点对照到各自的文档看看支持程度如何
然后花一天时间分别用这两个框架写一个用户登录注册什么的对比一下试试看

至于中文文档什么的存不存在就不要太依赖了,干了这行就要有啃英文文档的觉悟 只用过CI跟Yii,就UP主所描述的水平推测,CI会比较适合你,能在短期上手开发出产品
当然,CI的缺点是对面向对象的理解更偏向于简单的封装,基本上我还是觉得自己在做面向过程的工作(水平问题,你也可以自己设计很多类来灵活运用,但毕竟框架轻量,要完成复杂的设计还需要使用者有较高水平) 本人用过Yii2和Laravel,简单说一下。如果你们前端不怎么好,Yii的widget是一个很好的东西。前端无压力还漂亮。代码结构也清晰,IDE提示较好。
Laravle我觉得思想很先进,包括代码组织和php特性。但是不得不说Facades这些概念,有点过度设计。不过我觉得,前端同学很好的话,就用laravel Codeigniter 的文档相当丰富,Laravel 4 的资料不多。 Codeigniter 相当轻量级,下载下来就能用,Laravel 4 需要用 composer 下载安装各种第三方依赖库,在国内下载网速很慢。Codeigniter 兼容 PHP 5.2,Laravel 4 要求 PHP 5.3.7 以上。

Codeigniter 中 URL 都默认路由到某个 controller 的方法,Laravel 4 允许用 Router 自由定制,甚至可以用一个匿名函数来处理某些逻辑上相对独立的请求,例如验证码图片生成,而不必去定义一个控制器类。Codeigniter 的数据库操作一般采用 query builder 的方式,或者叫链式操作,Laravel 4 支持 query builder 方式以及 Eloquent ORM (非常好用,可以单独拆出来放在其他项目里)。Laravel 4 自带 artisan,以及一个很好用的插件 way/generators ,能够自动生成代码,完成数据库 migration 等等,Codeigniter 没有这类工具。Laravel 4 自带 phpunit 支持,可以方便写出单元测试。

最后,推荐一个 Laravel 4 的教程 :Code Bright : Code Bright ,写得比较通俗易懂。 Codeigniter 直觉化、轻量级、易学易用。如果要你自己写个PHP框架,出来估计就跟Codeigniter 差不多。你可以用它来写小东西,然后慢慢扩展。Codeigniter 不会妨碍你的规划和发展,只会规范你的程序架构。当然他的缺点也在于此:比较简陋,很多粗话还得自己慢慢弄。不过这不就是PHP的优点吗?如果你真的需要一个先进酷炫的框架,还是用rails是正道,甩PHP所有框架几条街不是问题。
推荐阅读
  • MVC设计模式的介绍和演化过程
    本文介绍了MVC设计模式的基本概念和原理,以及在实际项目中的演化过程。通过分离视图、模型和控制器,实现了代码的解耦和重用,提高了项目的可维护性和可扩展性。详细讲解了分离视图、分离模型和分离控制器的具体步骤和规则,以及它们在项目中的应用。同时,还介绍了基础模型的封装和控制器的命名规则。该文章适合对MVC设计模式感兴趣的读者阅读和学习。 ... [详细]
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
  • Todayatworksomeonetriedtoconvincemethat:今天在工作中有人试图说服我:{$obj->getTableInfo()}isfine ... [详细]
  • 数据库锁的分类和应用
    本文介绍了数据库锁的分类和应用,包括并发控制中的读-读、写-写、读-写/写-读操作的问题,以及不同的锁类型和粒度分类。同时还介绍了死锁的产生和避免方法,并详细解释了MVCC的原理以及如何解决幻读的问题。最后,给出了一些使用数据库锁的实际场景和建议。 ... [详细]
  • ps:写的第一个,不足之处,欢迎拍砖---只是想用自己的方法一步步去实现一些框架看似高大上的小功能(比如说模型中的toArraytoJsonsetAtt ... [详细]
  • 今天写一篇blog,已经多长时间没有更了,两个月了吧,没办法,现在银行开发,不能连外网,天天用虚拟机,真烦今天随手写点东西,主要是这两天对于springboot启动的分析,有所领悟 ... [详细]
  • 本文介绍了MVP架构模式及其在国庆技术博客中的应用。MVP架构模式是一种演变自MVC架构的新模式,其中View和Model之间的通信通过Presenter进行。相比MVC架构,MVP架构将交互逻辑放在Presenter内部,而View直接从Model中读取数据而不是通过Controller。本文还探讨了MVP架构在国庆技术博客中的具体应用。 ... [详细]
  • 从零基础到精通的前台学习路线
    随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
  • Asp.net Mvc Framework 七 (Filter及其执行顺序) 的应用示例
    本文介绍了在Asp.net Mvc中应用Filter功能进行登录判断、用户权限控制、输出缓存、防盗链、防蜘蛛、本地化设置等操作的示例,并解释了Filter的执行顺序。通过示例代码,详细说明了如何使用Filter来实现这些功能。 ... [详细]
  • 本文介绍了ASP.NET Core MVC的入门及基础使用教程,根据微软的文档学习,建议阅读英文文档以便更好理解,微软的工具化使用方便且开发速度快。通过vs2017新建项目,可以创建一个基础的ASP.NET网站,也可以实现动态网站开发。ASP.NET MVC框架及其工具简化了开发过程,包括建立业务的数据模型和控制器等步骤。 ... [详细]
  • MySQL数据库锁机制及其应用(数据库锁的概念)
    本文介绍了MySQL数据库锁机制及其应用。数据库锁是计算机协调多个进程或线程并发访问某一资源的机制,在数据库中,数据是一种供许多用户共享的资源,如何保证数据并发访问的一致性和有效性是数据库必须解决的问题。MySQL的锁机制相对简单,不同的存储引擎支持不同的锁机制,主要包括表级锁、行级锁和页面锁。本文详细介绍了MySQL表级锁的锁模式和特点,以及行级锁和页面锁的特点和应用场景。同时还讨论了锁冲突对数据库并发访问性能的影响。 ... [详细]
  • 本文讲述了作者从最初对软件工程的选择迷茫到逐渐喜欢并坚持学习的经历。作者在大学期间通过学习专业课和参与项目开发,不断挑战自己并取得成就感。虽然曾考虑过转专业和复读,但最终决定坚持学习软件工程,并为自己的未来努力奋斗。作者还提到了大学生活与自己最初的预期不同,但对此并没有太多抱怨。 ... [详细]
  • 使用J2SE模拟MVC模式开发桌面应用程序的工程包的介绍
    以我开发过的一个娱乐管理系统为例:下图为我系统的业务逻辑的MVC流程:下图为以Eclipse开发中各包的说明:转载于:https:blog ... [详细]
  • wpf+mvvm代码组织结构及实现方式
    本文介绍了wpf+mvvm代码组织结构的由来和实现方式。作者回顾了自己大学时期接触wpf开发和mvvm模式的经历,认为mvvm模式使得开发更加专注于业务且高效。与此同时,作者指出mvvm模式相较于mvc模式的优势。文章还提到了当没有mvvm时处理数据和UI交互的例子,以及前后端分离和组件化的概念。作者希望能够只关注原始数据结构,将数据交给UI自行改变,从而解放劳动力,避免加班。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
author-avatar
陈亮跑街向_114
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有