博客列表 >ThinkPHP5.0版本和ThinkPHP3.2版本的区别与联系

ThinkPHP5.0版本和ThinkPHP3.2版本的区别与联系

The Wolf Of Faith
The Wolf Of Faith原创
2017年08月28日 17:13:30624浏览

1.  URL和路由
    5.0的URL访问不再支持普通URL模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式:

    主要改进如下:
        增加路由变量规则;
        增加组合变量支持;
        增加资源路由;
        增加路由分组;
        增加闭包定义支持;
        增加MISS路由定义;
        支持URL路由规则反解析;

2. 请求对象和响应对象
    5.0新增了请求对象Request和响应对象Response,Request统一处理请求和获取请求信息,Response对象负责输出客户端或者浏览器响应。

3. 模块和控制器
    控制器的命名空间有所调整,并且可以无需继承任何的控制器类。
    应用命名空间统一为app(可定义)而不是模块名;
    控制器的类名默认不带Controller后缀,可以配置开启use_controller_suffix参数启用控制器类后缀;
    控制器操作方法采用return方式返回数据 而非直接输出;
    废除原来的操作前后置方法;
    增加beforeActionList属性定义前置操作;
    支持任意层次的控制器定义和访问;
    URL访问支持自动定位控制器;

4. 数据库
    5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:
    M('User')->where(['name'=>'thinkphp'])->find();     //3.2版本
    db('User')->where('name','thinkphp')->find();
  改进:
        支持链式查询操作;
        数据查询支持返回对象、数组和PDOStatement对象;
        数据集查询支持返回数组和Collection对象;
        增加查询构造器,查询语法改变;
        支持闭包查询;
        支持分块查询;
        支持视图查询;
        增加SQL监听事件;

5. 模型
    5.0的模型变化是最大的,基本上模型是完全面向对象的概念,包括关联模型,模型类的后缀不再带Model,直接由命名空间区分,原来的D函数调用改为model函数,并且必须创建对应的模型类,例如:
    D('User')->where(['name'=>'thinkphp'])->find();  //3.2
    model('User')->where('name','thinkphp')->find();  //5.0
    主要改进包括:
    重构关联模型;
    支持聚合模型;
    废除视图模型(改为数据库的视图查询方法);
    模型的扩展采用Trait机制;
    增加获取器和修改器;
    增加时间戳自动写入;
    增加类型字段转换;
    数组访问支持;
    JSON序列化支持;
自动验证和自动完成
    5.0的数据验证和自动验证完成和3.2版本区别比较大,5.0的数据验证采用验证器定义并且通过think\Validate类进行统一的验证。自动完成则通过在模型里面定义修改器来完成。

    异常
    5.0对错误零容忍,默认情况下会对任何级别的错误抛出异常(但可以在应用公共文件中设置错误级别),并且重新设计了异常页面,展示了详尽的错误信息,便于调试。

    调试和日志

    5.0的页面Trace强化,支持浏览器控制台查看Trace信息。
    5.0的日志驱动增加Socket方式,采用SocketLog支持远程调试。

6. 常量
    5.0版本废弃了原来的大部分常量定义,仅仅保留了框架的路径常量定义,其余的常量可以使用App类或者Request类的相关属性或者方法来完成,或者自己重新定义需要的常量。
    废除的常量包括:
    REQUEST_METHOD IS_GET IS_POST IS_PUT IS_DELETE IS_AJAX __EXT__ COMMON_MODULE MODULE_NAME         CONTROLLER_NAME ACTION_NAME APP_NAMESPACE APP_DEBUG MODULE_PATH

7.  函数
    5.0版本核心框架不依赖任何自定义函数,但仍然封装了一些常用功能到助手函数,你可以随意重新定义或者增加助手函数。

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议