Cover
前言
这几天接了几个外包的活,为了快速开发,也顺便了解一下ThinkPHP (以下简称TP),我大都选择了使用TP作为开发框架。使用几天之后,我便不想再使用VUE + iView + PhalAPI 的架构模式了。
只能说在快速开发这个方面,ThinkPHP绝对是最好之一。
所以我来写这篇文章,介绍这几天我在使用过程中的体验,以及我推荐它的理由。
由于我使用TP时间也只有一周,所以没办法面面俱到分析优缺点,有些方面可能有错误,还望指出。
ThinkPHP
TP作为一个MVC框架,对于基本的MVC模式实现之外,还提供了数据库模型关联,验证器等常用类,使用起来都十分方便,在我这几天的开发体验中,我主要体验到以下优点:
1. 模块机制
2. 参数绑定
3. 强大的ORM
4. 模版语法
5. 验证器
6. Cookie
7. 开发者友好
模块机制
TP提供了多模块机制,我可以在项目中独立创建多个模块,其默认会有一个Index模块和Common模块。
Index模块就是一般要开发的前台,如果我还要做一个后台,前后台的模型都是相同的,那么我会创建一个Admin模块,在其中开发后台,并在Common模块中写通用模型方法。在Index与Admin中共同调用Common的方法。这样的结构也很清晰,并且每一个模块都是一个独立的MVC架构。而如果没有模块机制,全项目依赖于一个MVC结构,那么在这种情景中C与V将会十分臃肿。
而设计原则就有:如果有分类,那么就必须分类。
TP的模块机制提供了一个项目中创建多个MVC的方式,是架构设计方面的一个很好的优点。
参数绑定
这其实是一个小优点,但是对于开发者来说,却是一个使用十分频繁的场景。无论是接口API还是表单处理,这都是一个很棒的用法。
在我之前使用的专为API设计的框架PhalAPI中,访问类的方法要带的参数需要声明一个getRules
方法来告诉这个类,访问什么方法绑定什么参数,虽然其提供了很多参数的属性绑定,但是我还是喜欢TP这种方法的参数定义就是接口API的参数定义这个设定。
所以说在TP中,你可以定义一个方法getNameById
,像下面那样:
Class User extends Controller {
...
public function getNameById ($id = 0) {
if ($id == 0) {
//没有传参数
return $this -> error();
}
return [
'id' => $id,
'name' => 'iimT'
];
}
...
然后在浏览器中访问http://localhost/Index/User/getNameById?id=2
,就会收到返回值:
{
id: 2,
name: 'iimT'
}
在请求中带的参数,被绑定在方法的参数中,这才符合人的第一直觉嘛。
强大的ORM
TP提供了很强大的ORM(基于PDO),除了最常用的Mysql之外,它还支持很多类型的数据库,下面是我在TP3.2版本找到的图,TP5没有找到类似的图:
我使用的是Mysql,所以不需要有过多配置,只需要开启PDO,填好配置文件的数据库访问信息就好了。
TP的Model类已经封装好了一系列常用的数据库操作,CURD都按照不同的使用场景被封装的很完善。如果你的数据库中有一张User
的表,要实现getById
只需要这样:
/* model/User.php */
use Think\Model;
Class User extends Model {
}
/* controller/User.php */
use Think\Controller;
use App\Model\User;
Class User extends Model {
public function getById ($id) {
$model = new User();
return $model -> get($id);
}
}
创建一个名叫User的Model然后在Controller中便可以直接使用。如果有较复杂的数据操作,便写在Model文件中。
除了方便的CURD,TP还提供了关联查询等高级操作,相比于其他框架这种操作就需要写原声Sql命令来执行了。在我这几天的使用中,TP的关联查询对我的效率提升绝对是利器。
模版语法
TP将原生在HTMl中嵌套<? ... >
标签的方法替换成了自己的模版标签,使用{}代替php标签,并封装了if-else、for、foreach等常用的渲染操作。其中{volist}当居模版使用频率之首,每次在写volist的时候,总有一种在写Vue的v-for的感觉,舒服极了。
验证器
TP提供了一个验证数据的类,用来对于不同的模型进行数据校验,在处理表单提交中尤为方便。而在之前,我们可能会使用多个if-else语句判断传入数据是否符合要求,比如用户注册场景,我们经常要做:
1. 用户名校验,无中文,长度限制,数字英文
2. 用户邮箱合法验证
3. 用户手机号合法验证
4. 用户密码长度限制,数字英文
这些事,之前的方案可能是if-else + RegEXP,但是对TP来说,则是小菜一碟,只需定义一个验证器:
namespace app\index\validate;
use think\Validate;
class User extends Validate
{
protected $rule = [
'name' => 'require|max:25',
'email' => 'require|email',
'pass' => 'require|max:18|min:8',
];
}
然后调用验证器类的check()
方法就可以完成对数据模型的验证。
Cookie
TP提供了对Cookie操作的封装,提供了Cookie类。但是我并没有使用这个类,而是使用它提供的助手函数cookie()
。这个助手函数就像jQuery一样简单:
1. 增:cookie("iimt", "Tmii")
就可以设置一个key为iimt值为Tmii的cookie。
2. 改:同上,再次设计就会被更改。
3. 查:cookie('iimt')
即可获取key为iimt的cookie值。
4. 删:cookie('iimt', null)
即可删除key为iimt的cookie。
开发者友好
我室友说第一次进入TP官网以为是盗版,没想到这真是官网。当然官网是有该吐槽的一面,但是TP对于开发者真是再友好不过了。
文档齐全
TP的文档写的很全,不管是哪一个版本,都有好几个文档可以看,收费的写的更细致一点,但是免费版完全开发手册完全够用了。
社区活跃
无论是在百度,还是TP论坛,还是github,总有很多人活跃着。有问题百度可以很快找到答案,并且由于开发者众多,基本你遇到的问题都能找到答案。如果找不到答案,社区发帖也会有很多人解答。而在github上,有无数TP做的项目,有成熟项目,也有上手模版。
Layui
这个前端组件库,现在基本是与TP绑在一起了,据我这几天的了解,至少一半的TP项目使用了Layui。而Layui也是一个十分优秀的前端组件库,对于使用webpack这么长时间的我来说,使用它没有丝毫不顺手。而我也将其当作TP生态的一部分作为推荐TP的开发者友好理由了。
总结
说了这么多,无非是推荐这个PHP的优秀MVC框架。
可以说在这几天上手中,我没有任何不适,完全被其圈粉。
如果你也有个新的idea想要实现的话,不妨也试试ThinkPHP。