thinkphp3和5的差別是什么

thinkphp3和5的差別是什么

需要摒棄的3.X舊思想

URL的變動

首先對3.X的不嚴謹給開發者們帶來的不正確的引導表示歉意,在5.0版本正式廢除類似/id/1方式 可以通過‘get’獲取到‘id’的方法,嚴格來講這樣的url是不屬于$_GET的,現在可以通過‘param’獲取,具體使用可以通過請求部分查詢。

模型的變動

立即學習PHP免費學習筆記(深入)”;

新版的模型查詢返回默認‘對象’,系統默認增加了’toArray’方法,許多開發者在’all’或’select’嘗試使用’toArray’來 轉換為數組,在此希望開發者能理解‘對象’的概念,嘗試使用‘對象’進行數據的使用,或者使用’db’方法進行數據庫的操作,也提醒一下部分‘濫 用’’toArray’的開發者,’all’或’select’結果是對象的數組集合,是無法使用’toArray’進行轉換的。

相關推薦:《ThinkPHP教程

新版變化

命名規范

·目錄和文件名采用‘小寫+下劃線’,并且以小寫字母開頭;

·類庫、函數文件統一以.php為后綴;

·類的文件名均以命名空間定義,并且命名空間的路徑和類庫文件所在路徑一致(包括大小寫);

·類名和類文件名保持一致,并統一采用駝峰法命名(首字母大寫)

函數

·系統已經不依賴任何函數,只是對常用的操作封裝提供了助手函數;

·單字母函數廢棄,默認系統加載助手函數,具體參考上一個章節‘助手函數’;

路由

5.0的URL訪問不再支持普通URL模式,路由也不支持正則路由定義,而是全部改為規則路由配合變量規則(正則定義)的方式,具體這里不再贅述。

控制器

控制器的命名空間有所調整,并且可以無需繼承任何的控制器類。

·應用類庫的命名空間統一為app(可修改)而不是模塊名;

·控制器的類名默認不帶 Controller 后綴,可以配置開啟 controller_suffix 參數啟用控制器類后綴;

·控制器操作方法采用 return 方式返回數據,而非直接輸出;

·廢除原來的操作前后置方法;

版本對比

3.2版本控制器寫法

<?php namespace HomeController; use ThinkController; class IndexController extends Controller  {     public function hello()     {         echo &#39;hello,thinkphp!&#39;;     } }

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-&gt;fetch('index/hello');

如果你的控制器沒有繼承 thinkController 的話,使用:

return?view('index/hello');

模型

如果非要對比與舊版本的改進,模型被分為數據庫、模型、驗證器三部分,分別對應M方法、模型、自動驗證,同時均有所加強,下面做簡單介紹。

數據庫

5.0的數據庫查詢功能增強,原先需要通過模型才能使用的鏈式查詢可以直接通過Db類調用,原來的M函數調用可以改用db函數,例如:?

3.2版本

M('User')-&gt;where(['name'=&gt;'thinkphp'])-&gt;find();

5.0版本

db('User')-&gt;where('name','thinkphp')-&gt;find();

模型

新版的模型查詢增加了靜態方法,例如:

User::get(1);? User::all(); User::where('id','&gt;',10)-&gt;find();

模型部分增強了很多功能,具體請查閱“模型章節”。

自動驗證

對比舊的版本,可以理解為之前的自動驗證且不同于之前的驗證;?

ThinkPHP5.0驗證使用獨立的 thinkValidate 類或者 驗證器 進行驗證,不僅適用于模型,在控制器也可直接調用,具體使用規則請參考“驗證”章節,這里不再贅述。

配置文件

新版對配置很多的配置參數或者配置層次都和之前不同了,建議大家要么看看代碼,要么仔細通讀下官方的開發手冊,不要因為配置的問題浪費自己一整天的時間。

異常

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 版本的單字母函數對比如下:

thinkphp3和5的差別是什么

1、過去的單字母函數已完全被替換掉,如下:

S=&gt;cache,C=&gt;config,M/D=&gt;model,U=&gt;url,I=&gt;input,E=&gt;exception,L=&gt;lang,A=&gt;controller,R=&gt;action

2、模版渲染:

$this-&gt;display()?=&gt;?return?view()/return?$this-&gt;fetch();

3、在model中調用自身model:

$this?=&gt;?Db::table($this-&gt;table)

4、在新建控制器與模型時的命名:

①控制器去掉后綴controller:UserController => User

②模型去掉后綴model:UserModel => User

5、url訪問:

如果控制器名使用駝峰法,訪問時需要將各字母之間用下劃線鏈接后進行訪問。

eg:控制器名為AddUser,訪問是用add_user來進行訪問

6、在TP5中支持配置二級參數(即二維數組),配置文件中,二級配置參數讀取:

①Config::get(‘user.type’);

②config(‘user.type’);

7、模板中支持三元運算符的運算:{$info.status ? $info.msg : $info.error}還支持這種寫法:{$varname.aa ?? ‘xxx’}或{$varname.aa ?: ‘xxx’}

8、TP5內置標簽:

系統內置的標簽中,volist、switch、if、elseif、else、foreach、compare(包括所有的比較標簽)、(not)present、(not)empty、(not)defined等。

9、TP5數據驗證:

$validate?=?new?Validate(['name'?=&gt;?'require|max:25','email'?=&gt;?'email']); $data?=?['name'?=&gt;?'thinkphp','email'?=&gt;?'thinkphp@qq.com']; if(!validate-&gt;check($data)){ debug::dump($validate-&gt;getError()); }

注:使用助手函數實例化驗證器——$validate = validate(‘User’);

10、TP5實現了內置分頁,使用如下:

查詢狀態為1的用戶數據,且每頁顯示10條數據

$list?=?model('User')-&gt;where('status',1)-&gt;paginate(10); $page?=?$this-&gt;render(); $this-&gt;assign('_list',$list); $this-&gt;assign('_page',$page); return?$this-&gt;fetch();

模板文件中分頁輸出代碼如下:

<div>{$_page}</div>

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊14 分享