TP5與TP3.X對比

 

首先聲明本章節並不是是指導升級舊的項目到5.0,而是爲了使用3.X版本的開發者更快的熟悉並上手這個全新的版本。同時也強烈建議開發者拋棄以前舊的思惟模式,由於5.0是一個全新的顛覆重構版本。php

 

須要摒棄的3.X舊思想

URL的變更

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

模型的變更

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

新版變化

命名規範

  • 目錄和文件名採用‘小寫+下劃線’,而且以小寫字母開頭;
  • 類庫、函數文件統一以.php爲後綴;
  • 類的文件名均以命名空間定義,而且命名空間的路徑和類庫文件所在路徑一致(包括大小寫);
  • 類名和類文件名保持一致,並統一採用駝峯法命名(首字母大寫)

函數

  • 系統已經不依賴任何函數,只是對經常使用的操做封裝提供了助手函數;
  • 單字母函數廢棄,默認系統加載助手函數,具體參考上一個章節‘助手函數’;

路由

5.0的URL訪問再也不支持普通URL模式,路由也不支持正則路由定義,而是所有改成規則路由配合變量規則(正則定義)的方式,具體這裏再也不贅述。數據庫

控制器

控制器的命名空間有所調整,而且能夠無需繼承任何的控制器類。數組

  • 應用類庫的命名空間統一爲app(可修改)而不是模塊名;
  • 控制器的類名默認不帶Controller後綴,能夠配置開啓controller_suffix參數啓用控制器類後綴;
  • 控制器操做方法採用return方式返回數據,而非直接輸出;
  • 廢除原來的操做先後置方法;

版本對比

3.2版本控制器寫法bash

<?php
namespace Home\Controller; use Think\Controller; class IndexController extends Controller { public function hello() { echo 'hello,thinkphp!'; } }

5.0版本控制器寫法markdown

namespace app\index\controller;

class Index { public function index() { return 'hello,thinkphp!'; } }

3.2版本控制器命名app

IndexController.class.php

5.0版本控制器命名ide

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

3.2版本 5.0版本
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 廢除
相關文章
相關標籤/搜索