首先聲明本章節並非是指導升級舊的項目到5.0
,而是為了使用3.X
版本的開發者更快的熟悉並上手這個全新的版本。同時也強烈建議開發者拋棄之前舊的思維模式,因為5.0
是一個全新的顛覆重構版本。
需要摒棄的3.X舊思想
URL的變動
首先對3.X的不嚴謹給開發者們帶來的不正確的引導表示歉意,在5.0版本正式廢除類似/id/1方式 可以通過‘get’獲取到‘id’的方法,嚴格來講這樣的url是不屬於$_GET的,現在可以通過‘param’獲取,具體使用可以通過請求部分查詢。
模型的變動
新版的模型查詢返回默認‘對象’,系統默認增加了'toArray'方法,許多開發者在'all'或'select'嘗試使用'toArray'來 轉換為數組,在此希望開發者能理解‘對象’的概念,嘗試使用‘對象’進行數據的使用,或者使用'db'方法進行數據庫的操作,也提醒一下部分‘濫 用’'toArray'的開發者,'all'或'select'結果是對象的數組集合,是無法使用'toArray'進行轉換的。
新版變化
命名規范
- 目錄和文件名采用‘小寫+下划線’,並且以小寫字母開頭;
- 類庫、函數文件統一以.php為后綴;
- 類的文件名均以命名空間定義,並且命名空間的路徑和類庫文件所在路徑一致(包括大小寫);
- 類名和類文件名保持一致,並統一采用駝峰法命名(首字母大寫)
函數
- 系統已經不依賴任何函數,只是對常用的操作封裝提供了助手函數;
- 單字母函數廢棄,默認系統加載助手函數,具體參考上一個章節‘助手函數’;
路由
5.0的URL訪問不再支持普通URL模式,路由也不支持正則路由定義,而是全部改為規則路由配合變量規則(正則定義)的方式,具體這里不再贅述。
控制器
控制器的命名空間有所調整,並且可以無需繼承任何的控制器類。
- 應用類庫的命名空間統一為app(可修改)而不是模塊名;
- 控制器的類名默認不帶
Controller
后綴,可以配置開啟controller_suffix
參數啟用控制器類后綴; - 控制器操作方法采用
return
方式返回數據,而非直接輸出; - 廢除原來的操作前后置方法;
版本對比
3.2版本控制器寫法
<?php namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function hello() { echo 'hello,thinkphp!'; } }
5.0版本控制器寫法
namespace app\index\controller; class Index { public function index() { return 'hello,thinkphp!'; } }
3.2版本控制器命名
IndexController.class.php
5.0版本控制器命名
Index.php
**在控制器中正確的輸出模板**
5.0在控制器中輸出模板,使用方法如下:
如果你繼承think\Controller
的話,可以使用:
return $this->fetch('index/hello');
如果你的控制器沒有繼承 think\Controller
的話,使用:
return view('index/hello');
模型
如果非要對比與舊版本的改進,模型被分為數據庫、模型、驗證器三部分,分別對應M方法、模型、自動驗證,同時均有所加強,下面做簡單介紹。
數據庫
5.0的數據庫查詢功能增強,原先需要通過模型才能使用的鏈式查詢可以直接通過Db類調用,原來的M函數調用可以改用db函數,例如:
3.2版本
M('User')->where(['name'=>'thinkphp'])->find();
5.0版本
db('User')->where('name','thinkphp')->find();
模型
新版的模型查詢增加了靜態方法,例如:
User::get(1); User::all(); User::where('id','>',10)->find();
模型部分增強了很多功能,具體請查閱“模型章節”。
自動驗證
對比舊的版本,可以理解為之前的自動驗證且不同於之前的驗證;
ThinkPHP5.0驗證使用獨立的\think\Validate
類或者驗證器進行驗證,不僅適用於模型,在控制器也可直接調用,具體使用規則請參考“驗證”章節,這里不再贅述。
配置文件
新版對配置很多的配置參數或者配置層次都和之前不同了,建議大家要么看看代碼,要么仔細通讀下官方的開發手冊,不要因為配置的問題浪費自己一整天的時間。
異常
5.0對錯誤零容忍,默認情況下會對任何級別的錯誤拋出異常,並且重新設計了異常頁面,展示了詳盡的錯誤信息,便於調試。
系統常量的廢棄
5.0版本相對於之前版本對系統變化進行了大量的廢棄,用戶如果有相關需求可以自行定義
下面是廢除常量
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等
部分常量可以在Request里面進行獲取,具體參考“請求章節”。
注:再次說明本章節僅僅為之前使用3.X版本開發者快速理解5.0所寫,具體5.0的功能還需要開發者通讀手冊。
助手函數
5.0
助手函數和3.2
版本的單字母函數對比如下:
3.2 版本 |
5.0 版本 |
---|---|
C | config |
E | exception |
G | debug |
L | lang |
T | 廢除 |
I | input |
N | 廢除 |
D | model |
M | db |
A | controller |
R | action |
B | 廢除 |
U | url |
W | widget |
S | cache |
F | 廢除 |