控制器定義
ThinkPHP V5.0的控制器定義比較靈活,可以無需繼承任何的基礎類,也可以繼承官方封裝的\think\Controller類或者其他的控制器類。
控制器定義
一個(ge)典型的(de)控(kong)制(zhi)器類定義如下:
namespace app\index\controller;
class Index
{
public function index()
{
return 'index';
}
}
控(kong)制器類(lei)文件的(de)實際位置是
application\index\controller\Index.php
控制器類可以無需繼承任何類,命名空間默認以app為根命名空間。
控制器的根命名空間可以設置,例如(ru)我們(men)在應(ying)用(yong)配置文件中修(xiu)改:
// 修改應(ying)用類庫(ku)命名空間
'app_namespace' => 'application',
V5.0.8+版本的話,app_namespace配置參數改為APP_NAMESPACE常量在入口文件中定義。
則實際(ji)的控制器類應該(gai)更改定(ding)義如下(xia):
namespace application\index\controller;
class Index
{
public function index()
{
return 'index';
}
}
只是命名空(kong)間改變(bian)了,但實(shi)際的(de)文件位(wei)置(zhi)和文件名并沒有改變(bian)。
使用該方式定(ding)義(yi)的控(kong)(kong)制器(qi)類(lei),如果要在控(kong)(kong)制器(qi)里(li)面渲染(ran)模板,可以(yi)使用
namespace app\index\controller;
use think\View;
class Index
{
public function index()
{
$view = new View();
return $view->fetch('index');
}
}
或者(zhe)直接使(shi)用view助手函數(shu)渲染(ran)模板(ban)輸出,例(li)如(ru):
namespace app\index\controller;
class Index
{
public function index()
{
return view('index');
}
}
如果繼承了think\Controller類的話,可以直接調用think\View及think\Request類的方法,例如:
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
public function index()
{
// 獲取包含域名的(de)完整URL地址
$this->assign('domain',$this->request->url(true));
return $this->fetch('index');
}
}
渲染輸出
默認情況下,控制器的輸出全部采用return的(de)方式,無需進行(xing)任何的(de)手(shou)動輸出(chu),系統(tong)會自動完(wan)成渲染(ran)內(nei)容(rong)的(de)輸出(chu)。
下面都是有效的(de)輸(shu)出方式(shi):
namespace app\index\controller;
class Index
{
public function hello()
{
return 'hello,world!';
}
public function json()
{
return json_encode($data);
}
public function read()
{
return view();
}
}
控制器一般不需要任何輸出(chu),直接return即可。
輸出轉換
默認情況下,控制器的返回輸出不會做任何的數據處理,但可以設置輸出格式,并進行自動的數據轉換處理,前提是控制器的輸出數據必須采用return的方式返回。
如果控制(zhi)器定義為:
namespace app\index\controller;
class Index
{
public function hello()
{
return 'hello,world!';
}
public function data()
{
return ['name'=>'thinkphp','status'=>1];
}
}
當我們(men)設置輸出數據格式為(wei)JSON:
// 默認輸(shu)出類型(xing)
'default_return_type' => 'json',
我們訪問
//localhost/index.php/index/Index/hello
//localhost/index.php/index/Index/data
輸出的結果變(bian)成:
"hello,world!"
{"name":"thinkphp","status":1}
默(mo)認(ren)情況下,控制器(qi)在ajax請求會對返回類型(xing)自(zi)動(dong)轉換,默(mo)認(ren)為json
如果我(wo)們(men)控制器定(ding)義
namespace app\index\controller;
class Index
{
public function data()
{
return ['name'=>'thinkphp','status'=>1];
}
}
我們訪問
//localhost/index.php/index/Index/data
輸出的結果(guo)變成:
{"name":"thinkphp","status":1}
當我們設置(zhi)輸出數據格式為html:
// 默認輸出類型(xing)
'default_ajax_return' => 'html',
這種情況下ajax請求不(bu)會對(dui)返回內容(rong)進行轉換(huan)
