CakePHPでヘルパーというのは、マニュアルでは
http://www.cakephp.jp/doc/helpers.htmlヘルパーは、データの整形や表示などの、ビューで一般に必要とされる関数を便利な仕方で提供する方法です。
と定義されており一般にビューで使用されるものだ。
しかし、CakePHPの標準で提供されているヘルパークラスの中には、TimeHelperクラスのdaysAsSqlメソッドなどSQLのwhere句を作成するのを助けてくれるような、コントローラクラスでぜひとも使用したい便利なメソッドも定義されている。
そこでコントローラ内で
var $helpers = array('Html', 'Form', 'Time');
と定義し、ビューファイルで$Time->daysAsSqlとアクセスするように、アクションメソッド内で
$sql = $Time->daysAsSql("2007/04/01", "2007/04/20", 'field');
として実行してみた。
しかし、$Time変数が定義されてないというエラーで失敗。
原因を調査してみると、ビューで使用する$Htmlや$Timeは、実はViewクラス(cake/libs/view/view.php)の_render(プロテクト)メソッドのローカル変数だからということが分かった。
(コントローラのset関数でビューに渡される関数もこの_render関数内でextractされている。)
そして、この_renderメソッドを覗いて見ると$this->_loadHelpersメソッドをコールしており、どうやらこの_loadHelpers内でヘルパークラスが作成されているというのがわかった。
_loadHelpersメソッドではコントローラの$helpersフィールドに定義されたヘルパークラスたちがnewされ、'base'や'webroot'などのコントローラクラスのフィールドをヘルパークラスのフィールドにコピーしている。
(実際にはコントローラからビューに設定されたフィールド)
ということは、コントローラ内で使用したいヘルパークラスをnewしてやればいいのではないかと考えコントローラ内のアクションメソッド内で
$Time = new TimeHelper();
としてみた。しかしTimeHelperクラスが見つからないとエラー。どうやらTimeHelperクラスのファイルが読み込まれてないみたいだ。
_loadHelpersメソッド内を調べてみるとloadHelper関数(グローバル)を使用し必要なヘルパークラスのファイルを読み込ませているのがわかった。
なので、コントローラクラスの任意のアクションメソッド内で
if(loadHelper('Time'))
{
$Time = new TimeHelper();
$sql = $Time->daysAsSql("2007/04/01", "2007/04/20", 'field');
echo $sql;
}
とloadHelper関数でヘルパークラスを読み込んでみると、
(field >= '2007-04-01 00:00:00') AND (field <= '2007-04-20 23:59:59')
と期待した結果が得られ、コントローラ内でへルパークラスを使用することに成功した。
これで今までコントローラ内にコピペしていたのがスッキリする・・・
ちなみに、loadHelper関数だが、cake/basics.phpで定義されている。
このファイルには他にもe()やh()などecho()やhtmlspecialchars()などのショートカット関数も定義されているみたいだ。
posted by asaton at 15:58|
Comment(0)
|
TrackBack(1)
|
CakePHP
|

|