|
|
@@ -0,0 +1,101 @@
|
|
|
+<?xml version="1.0" encoding="UTF-8"?>
|
|
|
+<!-- Reviewed: no -->
|
|
|
+<!-- EN-Revision: 17133 -->
|
|
|
+<sect2 id="zend.navigation.pages.custom">
|
|
|
+ <title>カスタム・ページ・タイプの作成</title>
|
|
|
+
|
|
|
+ <para>
|
|
|
+ <classname>Zend_Navigation_Page</classname>を拡張するとき、
|
|
|
+ 通常は、コンストラクタ、メソッド<methodname>setOptions()</methodname>、
|
|
|
+ または<methodname>setConfig()</methodname>をオーバーライドする必要はありません。
|
|
|
+ ページ・コンストラクタは単一のパラメータ、<type>Array</type>、
|
|
|
+ または<classname>Zend_Config</classname>オブジェクトを受け取ります。
|
|
|
+ そして、それはそれぞれ<methodname>setOptions()</methodname>
|
|
|
+ または<methodname>setConfig()</methodname>に渡されます。
|
|
|
+ それらのメソッドは次に<methodname>set()</methodname>メソッドを呼びます。
|
|
|
+ そして、オプションをネイティブまたはカスタムのプロパティにマップします。
|
|
|
+ もし、オプション<code>internal_id</code>が与えられたら、
|
|
|
+ メソッドは<methodname>setInternalId()</methodname>というメソッドを最初に探して、
|
|
|
+ それが存在するならばこのメソッドにオプションを渡します。
|
|
|
+ メソッドが存在しなければ、オプションはページのカスタム・プロパティとしてセットされて、
|
|
|
+ <code>$internalId = $page->internal_id;</code>または
|
|
|
+ <code>$internalId = $page->get('internal_id');</code>を通じてアクセスできます。
|
|
|
+ </para>
|
|
|
+
|
|
|
+ <example id="zend.navigation.custom.example.simple">
|
|
|
+ <title>もっとも単純なカスタム・ページ</title>
|
|
|
+
|
|
|
+ <para>
|
|
|
+ カスタム・ページ・クラスで実装する必要がある唯一のものは、
|
|
|
+ <methodname>getHref()</methodname>メソッドです。
|
|
|
+ </para>
|
|
|
+
|
|
|
+ <programlisting language="php"><![CDATA[
|
|
|
+class My_Simple_Page extends Zend_Navigation_Page
|
|
|
+{
|
|
|
+ public function getHref()
|
|
|
+ {
|
|
|
+ return 'something-completely-different';
|
|
|
+ }
|
|
|
+}
|
|
|
+]]></programlisting>
|
|
|
+ </example>
|
|
|
+
|
|
|
+ <example id="zend.navigation.custom.example.properties">
|
|
|
+ <title>プロパティ付のカスタム・ページ</title>
|
|
|
+
|
|
|
+ <para>
|
|
|
+ 拡張したページにプロパティを追加するとき、
|
|
|
+ <methodname>setOptions()</methodname>や<methodname>setConfig()</methodname>
|
|
|
+ メソッドをオーバーライドしたり、修正する必要はありません。
|
|
|
+ </para>
|
|
|
+
|
|
|
+ <programlisting language="php"><![CDATA[
|
|
|
+class My_Navigation_Page extends Zend_Navigation_Page
|
|
|
+{
|
|
|
+ private $_foo;
|
|
|
+ private $_fooBar;
|
|
|
+
|
|
|
+ public function setFoo($foo)
|
|
|
+ {
|
|
|
+ $this->_foo = $foo;
|
|
|
+ }
|
|
|
+
|
|
|
+ public function getFoo()
|
|
|
+ {
|
|
|
+ return $this->_foo;
|
|
|
+ }
|
|
|
+
|
|
|
+ public function setFooBar($fooBar)
|
|
|
+ {
|
|
|
+ $this->_fooBar = $fooBar;
|
|
|
+ }
|
|
|
+
|
|
|
+ public function getFooBar()
|
|
|
+ {
|
|
|
+ return $this->_fooBar;
|
|
|
+ }
|
|
|
+
|
|
|
+ public function getHref()
|
|
|
+ {
|
|
|
+ return $this->foo . '/' . $this->fooBar;
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+//これで、利用して構築できます
|
|
|
+$page = new My_Navigation_Page(array(
|
|
|
+ 'label' => 'Property names are mapped to setters',
|
|
|
+ 'foo' => 'bar',
|
|
|
+ 'foo_bar' => 'baz'
|
|
|
+));
|
|
|
+
|
|
|
+//または
|
|
|
+$page = Zend_Navigation_Page::factory(array(
|
|
|
+ 'type' => 'My_Navigation_Page',
|
|
|
+ 'label' => 'Property names are mapped to setters',
|
|
|
+ 'foo' => 'bar',
|
|
|
+ 'foo_bar' => 'baz'
|
|
|
+));
|
|
|
+]]></programlisting>
|
|
|
+ </example>
|
|
|
+</sect2>
|