午夜91福利视频,午夜成人在线观看,午夜在线视频免费观看,午夜福利短视频,精品午夜成人免费视频APP

控制器定義

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\Viewthink\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)

文檔最后更新時間:2018-04-26 08:29:13

文檔
目錄(lu)

深色
模(mo)式

切換
寬(kuan)度