thinkphp3和thinkphp5的區別?下面給大家介紹一下兩者的不同之處:
一、thinkphp3.2和thinkphp5之間的使用差異
1、過去的單字母函數已完全被替換掉,如下:
S=>cache,C=>config,M/D=>model,U=>url,I=>input,E=>exception,L=>lang,A=>controller,R=>action
2、模版渲染:
立即學習“PHP免費學習筆記(深入)”;
$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中支持配置二級參數(即二維數組),配置文件中,二級配置參數讀?。?/p>
①Config::get(‘user.type’);
②config(‘user.type’);
{$info.status???$info.msg?:?$info.error}還支持這種寫法:{$varname.aa????'xxx'}或{$varname.aa??:?'xxx'}
相關推薦:《php視頻教程》
8、TP5內置標簽:
系統內置的標簽中,volist、switch、if、elseif、else、foreach、compare(包括所有的比較標簽)、(not)present、(not)empty、(not)defined等
9、TP5數據驗證:
$validate?=?new?Validate(['name'?=>?'require|max:25','email'?=>?'email']); $data?=?['name'?=>?'thinkphp','email'?=>?'thinkphp@qq.com']; if(!validate->check($data)){ debug::dump($validate->getError()); }
注:使用助手函數實例化驗證器——$validate = validate(‘User’);
10、TP5實現了內置分頁,使用如下:
查詢狀態為1的用戶數據,且每頁顯示10條數據
$list?=?model('User')->where('status',1)->paginate(10); $page?=?$this->render(); $this->assign('_list',$list); $this->assign('_page',$page); return?$this->fetch();
模板文件中分頁輸出代碼如下:
<div>{$_page}</div>
第二、thinkphp3.2和thinkphp5數據庫操作進行對比
增加數據
thinkhp3.2
//添加單條數據$User?=?M('User'); $data['name']?=?'ThinkPHP'; $data['email']?=?'ThinkPHP@gmail.com'; $User->create($data); $User->add($data);//添加多條數據$dataList[]?=?array('name'=>'thinkphp','email'=>'thinkphp@gamil.com'); $dataList[]?=?array('name'=>'onethink','email'=>'onethink@gamil.com') $User->addAll($dataList);
thinkphp5
//添加單條數據$data?=?['foo'?=>?'bar',?'bar'?=>?'foo']; Db::table('think_user')->insert($data);//添加多條數據$data?=?[ ????['foo'?=>?'bar',?'bar'?=>?'foo'], ????['foo'?=>?'bar1',?'bar'?=>?'foo1'], ????['foo'?=>?'bar2',?'bar'?=>?'foo2'] ]; Db::name('user')->insertAll($data);
修改數據
thinkhp3.2
$User?=?M("User");?//?實例化User對象//?要修改的數據對象屬性賦值 $data['name']?=?'ThinkPHP';$data['email']?=?'ThinkPHP@gmail.com'; $User->where('id=5')->save($data);?//?根據條件更新記錄 where('id=5')->setField('name','ThinkPHP'); $data?=?array('name'=>'ThinkPHP','email'=>'ThinkPHP@gmail.com');//?更改用戶的name值 $User->?where('id=5')->setField($data);更改用戶的name和email的值 $User->where('id=5')->setDec('score',5);?//?用戶的積分減5 $User->where('id=5')->setInc('score',3);?//?用戶的積分加3
thinkhp5
Db::table('think_user')->update(['name'?=>?'thinkphp','id'=>1]);//更新數據表中的數據 Db::table('think_user')?->where('id',1)?->setField('name',?'thinkphp');//更新某個字段的值 Db::table('think_user')->where('id',?1)->setInc('score',5);//?score?字段加?5 Db::table('think_user')->where('id',?1)->setDec('score',?5);//?score?字段減?5 Db::table('think_user')->where('id',?1)->setInc('score',?1,?10);//支持延時更新
刪除數據
thinkhp3.2
$User->delete('1,2,5');?//?刪除主鍵為1,2和5的用戶數據 $User->where('status=0')->delete();?//?刪除所有狀態為0的用戶數據
thinkphp5
//?根據主鍵刪除Db::table('think_user')->delete(1); Db::table('think_user')->delete([1,2,3]);//?條件刪除???? Db::table('think_user')->where('id',1)->delete(); Db::table('think_user')->where('id','delete();
第三、thinkphp5與thinkphp3.X對比
首先聲明本章節并非是指導升級舊的項目到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 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方法、模型、自動驗證,同時均有所加強,下面做簡單介紹。
數據庫
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驗證使用獨立的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里面進行獲取
助手函數
5.0助手函數和3.2版本的單字母函數對比如下: