thinkphp5和3的區(qū)別

thinkphp5和3的區(qū)別

首先聲明本章節(jié)并非是指導(dǎo)升級舊的項目到5.0,而是為了使用3.X版本的開發(fā)者更快的熟悉并上手這個全新的版本。同時也強烈建議開發(fā)者拋棄之前舊的思維模式,因為5.0是一個全新的顛覆重構(gòu)版本。

需要摒棄的3.X舊思想

URL的變動

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

立即學(xué)習(xí)PHP免費學(xué)習(xí)筆記(深入)”;

模型的變動

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

新版變化

命名規(guī)范

目錄和文件名采用‘小寫+下劃線’,并且以小寫字母開頭;類庫、函數(shù)文件統(tǒng)一以.php為后綴;類的文件名均以命名空間定義,并且命名空間的路徑和類庫文件所在路徑一致(包括大小寫);類名和類文件名保持一致,并統(tǒng)一采用駝峰法命名(首字母大寫)

函數(shù)

系統(tǒng)已經(jīng)不依賴任何函數(shù),只是對常用的操作封裝提供了助手函數(shù);單字母函數(shù)廢棄,默認系統(tǒng)加載助手函數(shù),具體參考上一個章節(jié)‘助手函數(shù)’;

路由

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

控制器

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

應(yīng)用類庫的命名空間統(tǒng)一為app(可修改)而不是模塊名;控制器的類名默認不帶Controller后綴,可以配置開啟controller_suffix參數(shù)啟用控制器類后綴;控制器操作方法采用return方式返回數(shù)據(jù),而非直接輸出;廢除原來的操作前后置方法;

版本對比

3.2版本控制器寫法

<?phpnamespace  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');

模型

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

數(shù)據(jù)庫

5.0的數(shù)據(jù)庫查詢功能增強,原先需要通過模型才能使用的鏈?zhǔn)讲樵兛梢灾苯油ㄟ^Db類調(diào)用,原來的M函數(shù)調(diào)用可以改用db函數(shù),例如:

3.2版本

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

5.0版本

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

模型

新版的模型查詢增加了靜態(tài)方法,例如:

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

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

自動驗證

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

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

配置文件

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

異常

5.0對錯誤零容忍,默認情況下會對任何級別的錯誤拋出異常,并且重新設(shè)計了異常頁面,展示了詳盡的錯誤信息,便于調(diào)試。

系統(tǒng)常量的廢棄

5.0版本相對于之前版本對系統(tǒng)變化進行了大量的廢棄,用戶如果有相關(guān)需求可以自行定義

下面是廢除常量

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里面進行獲取,具體參考“請求章節(jié)”。

注:再次說明本章節(jié)僅僅為之前使用3.X版本開發(fā)者快速理解5.0所寫,具體5.0的功能還需要開發(fā)者通讀手冊。

助手函數(shù)

5.0助手函數(shù)和3.2版本的單字母函數(shù)對比如下:

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? ? 廢除? ??

更多ThinkPHP相關(guān)技術(shù)文章,請訪問ThinkPHP使用教程欄目進行學(xué)習(xí)!

以上就是

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點贊15 分享