浅谈 ThinkPHP5.0 版本和 ThinkPHP3.2 版本的区别

浅谈 ThinkPHP5.0 版本和 ThinkPHP3.2 版本的区别

5.0 版本和之前版本的差异较大,本篇对熟悉 3.2 版本的用户给出了一些 5.0 的主要区别。

URL 和路由

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

主要改进如下:

增加路由变量规则;
增加组合变量支持;
增加资源路由;
增加路由分组;
增加闭包定义支持;
增加 MISS 路由定义;
支持 URL 路由规则反解析;

请求对象和响应对象

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

模块和控制器

控制器的命名空间有所调整,并且可以无需继承任何的控制器类。

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

数据库

5.0 的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过 Db 类调用,原来的 M 函数调用可以改用 db 函数,例如:

3.2 版本

M(‘User’)->where([‘name’=>‘thinkphp’])->find();

5.0 版本

db(‘User’)->where(‘name’,‘thinkphp’)->find();

主要改进如下:

支持链式查询操作;
数据查询支持返回对象、数组和 PDOStatement 对象;
数据集查询支持返回数组和 Collection 对象;
增加查询构造器,查询语法改变;
支持闭包查询;
支持分块查询;
支持视图查询;
增加 SQL 监听事件;

模型

5.0 的模型变化是最大的,基本上模型是完全面向对象的概念,包括关联模型,模型类的后缀不再带 Model,直接由命名空间区分,原来的 D 函数调用改为 model 函数,并且必须创建对应的模型类,例如:

3.2 版本

D(‘User’)->where([‘name’=>‘thinkphp’])->find();

5.0 版本

model(‘User’)->where(‘name’,‘thinkphp’)->find();

主要改进包括:

重构关联模型;
支持聚合模型;
废除视图模型(改为数据库的视图查询方法);
模型的扩展采用 Trait 机制;
增加获取器和修改器;
增加时间戳自动写入;
增加类型字段转换;
数组访问支持;
JSON 序列化支持;

自动验证和自动完成

5.0 的数据自动验证和自动完成和 3.2 版本区别较大,5.0 的数据验证采用验证器定义并且通过 think\Validate 类进行统一的验证。自动完成则通过在模型里面定义修改器来完成。

异常

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

调试和日志

5.0 的页面 Trace 强化,支持浏览器控制台查看 Trace 信息。

5.0 的日志驱动增加 Socket 方式,采用 SocketLog 支持远程调试。

常量

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

函数

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

以上这篇浅谈 ThinkPHP5.0 版本和 ThinkPHP3.2 版本的区别就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

官方说过了,不要用 3 的思维去用 5。这样说吧算是官方出的俩个产品,并非版本迭代的关系。目录结构不一样,有些函数名不一样。如果是传统的 mvc 网站,用 tp3.2。如果是做接口,就用 tp5。前后主要差别应该就是对于 view 的处理。

模型实例化
TP5 取消了自动实例化模型的 M 方法,转而使用了新的实例化模型方法。没有自动实例化则必须自己新建模型类,然后自己实例化,这就有点类似 D 方法。这里与 D 方法的功能类似的有一个 model 的方法,功能上完全可以替换使用

U 方法
U 方法是 TP 中的生成路由的内置方法,现在这个方法可以完全使用 url 方法替换

TP5 中取消了 IS_GET 和 IS_POST 方法
如果想继续使用可以在项目中自定义一下,如下:

define(‘IS_GET’,Request::instance()->isGet());
define(‘IS_POST’, Request::instance()->isPost());
1
2
1
2
原来的 TP 的 I 方法
之前的 TP 有个 I 方法用来接收请求参数,目前可以使用 input 方法替代

需要注意的是新增方法
现在的单条新增方法改为了 save 方法,这个是以前的更新方法,而且需要注意的是更新的方式也有区别。新增可以直接用 save,而更新则需要加 isUpdate(true)

model("")->isUpdate(true)->save($data);
1
1
TP5 和原来版本 TP 差距最大的功能性的地方在返回,现在几乎所有的数据库查询都会返回对象
$menuurl->find($menu_id);// 此方法返回一个对象,可以使用 ->toArray() 方法转换为数组
$this->where($condition)->order($order)->select();// 此方法返回一个对象数组,所以要使用数据也必须转换,当然可以直接用对象
1
2
1
2
C 方法被 config 方法替换
数据库配置单独在 database.php 中,想获取参数使用
config(‘database.prefix’)
1
1
页面中目前有自定义常量的方法,使用配置的方法类似之前版本
如果需要全局替换的话,可以直接在配置文件中添加:
‘view_replace_str’ => [
PUBLIC’=>‘/public/’,
ROOT’ => ‘/’,
]
或者直接使用常量配置
{$Think.config.PUBLIC}
1
2
3
4
5
6
7
1
2
3
4
5
6
7
默认的引擎标签可修改,也就是之前的 <> 这种可以继续用
// 模板引擎普通标签开始标记
‘tpl_begin’ => ‘{’,
// 模板引擎普通标签结束标记
‘tpl_end’ => ‘}’,
// 标签库标签开始标记
‘taglib_begin’ => ‘{’,
// 标签库标签结束标记
‘taglib_end’ => ‘}’,

5.0 的入口文件是放在 public 文件夹下面,所以如果要单独配置站点,则需要选到 public 文件夹
模板渲染方面:5.0 使用的是:
return $this->fetch();(fetch 里不带参数,是自动定位到当前操作的模板文件,如果带参数就跟原来的一样)
数据库方面:5.0 在使用数据库时将 U、M 等函数去掉,统一使用 Db(“表名”),例如:
db(‘User’)->where(‘name’,‘thinkphp’)->find();
还可以使用:
Db::table(‘think_user’)->where(‘id’,1)->find();(但使用 Db::table(“表名”) 时,要 use think\Db,否则会报错)
模板跳转(如 a 链接跳转,form 表单跳转)方面:将 3.2 原来的 {:U()} 替换成{:url()}, 例如:
action=“{:url(‘index/login/doLogin’)}”
引用 CSS、JS 或其他文件:这个 thinkphp/library/think/View.php 文件中可以看到:
STATIC:是直接指到 public 的 static, 相当于 3.2 中的 __PUBLIC__;
CSS:是直接指到 static 的 css 下面,这里可以修改的
JS: 也是跟 __CSS__ 一样、