##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 'hello,thinkphp!'; } }5.0版本控制器寫法
namespace app\index\controller; class Index { public function index() { return 'hello,thinkphp!'; } }3.2版本控制器命名
IndexController.class.php5.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 版本的单字母函数对比如下:
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(['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和5的差異是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!