URL的变动
首先:对3.X的不严谨给开发者们带来的不正确的引导表示歉意,在5.0版本正式废除类似/id/1方式 可以通过‘get’获取到‘id’的方法,严格来讲这样的url是不属于$_GET的,现在可以通过‘param’获取,具体使用可以通过请求部分查询。
view层跳转页面:
1)直接写方法名 : 模块/控制器/方法 = home/index/index
2)url跳转 :{:url('index/show', ['id' => $id])}
controller层接值问题:
1)如果用第一种方法跳转页面,可以用request()->get('id') 或者 input('get.id') 来接收
2)如果用第二中方法跳转页面,则用Request()::instance()->param('id')来接收
模型的变动
新版的模型查询返回默认‘对象’,系统默认增加了'toArray'方法,许多开发者在'all'或'select'尝试使用'toArray'来 转换为数组,在此希望开发者能理解‘对象’的概念,尝试使用‘对象’进行数据的使用,或者使用'db'方法进行数据库的操作,也提醒一下部分‘滥 用’'toArray'的开发者,'all'或'select'结果是对象的数组集合,是无法使用'toArray'进行转换的
控制器
控制器的命名空间有所调整,并且可以无需继承任何的控制器类。
- 应用类库的命名空间统一为app(可修改)而不是模块名;
- 控制器的类名默认不带
Controller
后缀,可以配置开启controller_suffix
参数启用控制器类后缀; - 控制器操作方法采用
return
方式返回数据,而非直接输出; - 废除原来的操作前后置方法;
版本对比
3.2版本控制器写法
<?php
namespace HomeController;
use ThinkController;
class IndexController extends Controller
{
public function hello()
{
echo 'hello,thinkphp!';
}
}
5.0版本控制器写法
namespace appindexcontroller;
class Index
{
public function index()
{
return 'hello,thinkphp!';
}
}
3.2版本控制器命名
IndexController.class.php
5.0版本控制器命名
Index.php
**在控制器中正确的输出模板**
5.0在控制器中输出模板,使用方法如下:
如果你继承thinkController
的话,可以使用:
return $this->fetch('index/hello');
如果你的控制器没有继承 thinkController
的话,使用:
return view('index/hello');
模型
如果非要对比与旧版本的改进,模型被分为数据库、模型、验证器三部分,分别对应M方法、模型、自动验证,同时均有所加强,下面做简单介绍。
1)数据库
5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:
3.2版本
M('User')->where(['name'=>'thinkphp'])->find();
5.0版本
db('User')->where('name','thinkphp')->find();
2)模型
新版的模型查询增加了静态方法,例如:
User::get(1);
User::all();
User::where('id','>',10)->find();
模型部分增强了很多功能,具体请查阅“模型章节”。
3)自动验证
对比旧的版本,可以理解为之前的自动验证且不同于之前的验证;
ThinkPHP5.0验证使用独立的 hinkValidate
类或者验证器进行验证,不仅适用于模型,在控制器也可直接调用,具体使用规则请参考“验证”章节,这里不再赘述。