Thinkphp与CI的区别

深入学习一门新技术的最好方法就是看官方文档。

ThinkPHP5.0文档:

http://www.kancloud.cn/manual/thinkphp5/118003

Thinkphp与CI的区别

官方的说辞是:

主要特性

规范:遵循PSR-2、PSR-4规范,Composer及单元测试支持;

严谨:异常严谨的错误检测和安全机制,详细的日志信息,为你的开发保驾护航; 灵活:减少核心依赖,扩展更灵活、方便,支持命令行指令扩展;

API友好:出色的性能和REST支持、远程调试,更好的支持API开发; 高效:惰性加载,及路由、配置和自动加载的缓存机制;

ORM:重构的数据库、模型及关联,MongoDb支持;

只是:

不适合原有3.2项目的升级,请慎重考虑商业项目升级,但绝对是新项目的首选(无论是WEB还是API开发)

可以说是web后端该有的接口都有,最大程度满足使用。

之前学习使用过CodeIgniter(即CI),我简单的将它与CI的功能做下对比:

  1. 模型(Model):模板相当于对数据的操作,数据存放的形式有多种:如数据库、文件系统、内存等。CI没有强制绑定模板对数据库的操作,而ThinkPHP(以下称TP)默认跟数据库操作强相关,确实实际中操作的数据一般都是数据库的,但要操作其他存储类型的数据要怎么办呢?其实TP只是提供了操作数据的许多便利接口,只要不使用这些接口,还是不耦合的;而且存储类型的驱动是可配置的,比如可改为文件数据操作。所以TP要方便的多。
  2. 命名空间的使用。CI党体会不到命名空间带来的便利与优雅。CI使用$this->load()导入不同模块的两个model时应该是冲突的,应该是可以覆盖,但使用起来就不方便了。
  3. TP很讲究使用的便利性,所以提供了很多函数助手,一般正常使用是$a=Class::function();,使用助手之后一般是$a = class();,便利了不少,这个使用上看习惯吧。CI就要麻烦冗长地写成$this->class->function()

  4. 说说视图(view)与模板(template)。CI的视图文件的存放位置是application/view下面,而且不可配置,至少我没找到可以配置的地方。TP的view目录可配置,而且不一定要在application下,对安全访问和视图定制与替换提供比较大的便利性。

    对于模板,CI实现得比较鸡肋,虽说有个模板解析类 $this->load->library('parser'); 可以通过左边这代码加载,但是只能实现变量的简单替换,较复杂的控制结构就实现不了了,到头来还是用原生的php代码实现(我估计官方也提倡用原生,毕竟原生不用多解析一般,效率上占优,语法也不用再学一套)。

    而TP的模板就比较全面和成熟,有自己的一套语法,基本上是不用夹杂原生php,也许对于前端工程师来说是个好事吧,不用学php,就学个模板语法。前后端分工也就更加明确了。

  5. 现在一想,CI和TP的MVC目录结构有着比较大的区别:
  6. CI的controllers、view、model就各分别一个目录,模块的划分是以上面各目录下新建子目录作为模块目录,或者干脆没有模块的概念,直接在目录下创建控制器和模型等。
  7. 而TP是以模块作为基本的隔离单元,默认各个模板所对应的目录下都有一个controllers、view、model目录。

  8. 至于调试(debug),TP绝对是甩CI几条街,官方提供的方法就有:

Thinkphp与CI的区别

而CI只有简单的将错误的调用暂打印出来,虽说这已经可以解决60%以上的问题了。

所以问题来了,为什么CI在国外也很流行,国内也有一定数量的公司在使用呢?

还是用官方的话说吧:

CodeIgniter 就是你所需要的,如果...

你想要一个小巧的框架;

你需要出色的性能;

你需要广泛兼容标准主机上的各种 PHP 版本和配置;

你想要一个几乎零配置的框架;

你想要一个不需使用命令行的框架;

你想要一个不想被编码规则的条条框框限制住的框架;

你对 PEAR 这种庞然大物不感兴趣;

你不想*学习一种新的模板语言(当然如果你喜欢,你可以选择一个模板解析器);

你不喜欢复杂,追求简单;

你需要清晰、完整的文档。

所以,CI学习起来和用起来十分简单和上手,框架非常轻量,这就成为一部分想要高性能又不想受框架过多约束的公司的首选了。

TP与CI的区别就先讲到这里,后面随着学习的深入可能会有所补充。

-end-

上一篇:Python之路【第三篇】:Python基础(二)


下一篇:移动端web开发的一些知识点