首頁 >php框架 >ThinkPHP >thinkphp3和5的差異是什麼

thinkphp3和5的差異是什麼

爱喝马黛茶的安东尼
爱喝马黛茶的安东尼原創
2019-08-26 15:36:593667瀏覽

thinkphp3和5的差異是什麼

##URL的變動

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

模型的變動

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

相關推薦:《

ThinkPHP教學

#新版變更

命名規範

·

目錄和檔案名稱採用'小寫下劃線',並且以小寫字母開頭;

·

類別庫、函數文件統一以.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 &#39;hello,thinkphp!&#39;;
    }
}
5.0版本控制器寫法
namespace app\index\controller;
class Index 
{
    public function index()
    {
        return &#39;hello,thinkphp!&#39;;
    }
}

3.2版本控制器命名

IndexController.class.php

5.0版本控制器命名

Index.php
**在控制器中正確的輸出模板**

5.0在控制器中輸出模板,使用方法如下:

如果你繼承think\Controller 的話,可以使用:

return $this->fetch(&#39;index/hello&#39;);

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

return view(&#39;index/hello&#39;);
模型

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

資料庫

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

3.2版本

M(&#39;User&#39;)->where([&#39;name&#39;=>&#39;thinkphp&#39;])->find();

5.0版本

db(&#39;User&#39;)->where(&#39;name&#39;,&#39;thinkphp&#39;)->find();
模型

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

User::get(1); 
User::all();
User::where(&#39;id&#39;,&#39;>&#39;,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 版本的单字母函数对比如下:

thinkphp3和5的差異是什麼

1、过去的单字母函数已完全被替换掉,如下:

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

2、模版渲染:

$this->display() => return view()/return $this->fetch();

3、在model中调用自身model:

$this => Db::table($this->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([&#39;name&#39; => &#39;require|max:25&#39;,&#39;email&#39; => &#39;email&#39;]);
$data = [&#39;name&#39; => &#39;thinkphp&#39;,&#39;email&#39; => &#39;thinkphp@qq.com&#39;];
if(!validate->check($data)){
debug::dump($validate->getError());
}

注:使用助手函数实例化验证器——$validate = validate('User');

10、TP5实现了内置分页,使用如下:

查询状态为1的用户数据,且每页显示10条数据

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

模板文件中分页输出代码如下:

<div>{$_page}</div>

以上是thinkphp3和5的差異是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn