ginkgo


控制器概况

ginkgo 的控制器定义比较灵活,无需继承任何基础类,也可以继承框架预先封装的 ginkgo\Ctrl 类或者其他的控制器类。


控制器定义

一个典型的控制器类定义如下:

namespace app\ctrl\index;

class Index {
    public function index() {
        return 'index';
    }
}

控制器的实际位置是

app/ctrl/index/index.ctrl.php

控制器类可以无需继承任何类,命名空间默认以 app 为根命名空间。

如果要在控制器里面渲染模板,可以使用:

namespace app\ctrl\index;

use ginkgo\View;

class Index {
    public function index() {
        $view = View::instance();

        return $view->fetch('index');
    }
}

如果继承了 ginkgo\Ctrl 类,可以直接调用如下类的实例:

class Ctrl {
    // ginkgo\Request 的实例
    protected $obj_request;

    // ginkgo\View 的实例
    protected $obj_view;

    // ginkgo\Lang 的实例
    protected $obj_lang;
}

例如:

namespace app\ctrl\index;

use ginkgo\Ctrl;

class Index extends Ctrl {
    public function index() {
        // 获取包含域名的完整 URL 地址
        $this->assign('domain', $this->obj_request->root(true));

        return $this->fetch('index');
    }
}

渲染输出

默认情况下,控制器的输出全部采用 return 的方式,无需进行任何的手动输出,系统会自动完成渲染内容的输出。下面都是有效的输出方式:

namespace app\ctrl\index;

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

    public function json() {
        return json_encode($data);
    }

    public function read() {
        $view = View::instance();

        return $view->fetch('index');
    }
}

控制器一般不需要任何输出,直接 return 即可。


特别注意

根据 概况 -> 开发规范 的要求,方法的命名使用驼峰法(首字母小写),但是路由都使用小写,并且系统会强制转换 URL 请求,因此 ginkgo 采用了一种自动转换的策略,当路由中的动作命名为小写字母和下划线或横杠时,系统会将动作自动转换为驼峰法(首字母小写)。

如果当前访问的地址是

http://server/index.php/index/index/hello-world

http://server/index.php/index/index/hello_world

控制器类定义如下:

namespace app\ctrl\index;

class Index {
    public function helloWorld() {
        return 'hello_world';
    }
}

v0.1.1 起 hello-world 的形式有效