CD Collectionアプリケーションのやり直し

そのため、 前のトピック (ブログの購読者にのみ表示!)で、 NetTuts + Webサイトに投稿された小花に関する記事を参照しました。 それに記載されているアプリケーションには欠点があるので、それらを見つけて無力化することを提案します。



1.テンプレートを使用した作業の最適化(VIEWS)





各テンプレートがゼロからページを作成する必要性を気にしませんか(Doctype、スタイルなどを含む)? 静的に切り替えるのはそう長くはありません。 したがって、最初の考えは、ネストされたテンプレートを実装することです。



すべてのテンプレートには特定の共通部分があり、個別のファイルに配置され、各コントローラーメソッドで接続されます。 viewsフォルダーにindex.phpファイルを作成します。

<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  1. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  2. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  3. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  4. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  5. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  6. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  7. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  8. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  9. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  10. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  11. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  12. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  13. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  14. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  15. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  16. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  17. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  18. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  19. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  20. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  21. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  22. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  23. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



  24. <! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .



<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd" > < html > < head > <? php echo html::stylesheet ( array ( 'assets/css/style' ), array ( 'screen' ), FALSE ); ? > < title > CD COLLECTION </ title > </ head > < body > <!-- BEGIN NAVIGATION MENU --> < ul id ="navigation" > < li ><? =html::anchor('album', 'Albums')? ></ li > </ ul > <!-- END NAVIGATION MENU --> <? =$content? > </ body > </ html > * This source code was highlighted with Source Code Highlighter .







別のファイルにページヘッダーを配置し、独自にナビゲーションメニューを追加しました(これまでのところ、ある時点からですが、後で拡張します)。 コントローラーAlbum_Controllerの結果が含まれる変数$ contentに注意してくださいstyle.cssファイルに次の行を追加します(ナビゲーションメニューの規則):







  1. #navigation {
  2. オーバーフロー:非表示。
  3. list-style-type:なし;
  4. }
  5. #navigation li {
  6. float:左;
  7. マージン左:0.5em;
  8. 境界線:1px黒一色;
  9. }
  10. #navigation li a {
  11. フォントサイズ:14px;
  12. ディスプレイ:ブロック;
  13. パディング:2px 5px;
  14. テキスト装飾:なし;
  15. 色:#fff;
  16. 背景:#666;
  17. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




次に、使用可能なテンプレートの余分な部分をすべて切り取ります。 list.phpファイルの例を使用して、最終結果を表示します。







  1. <? 定義済みの php'SYSPATH'または die'直接スクリプトアクセスなし' );
  2. echo html :: image'assets / images / add.png' );
  3. echo html :: anchor'album / show_create_editor''Add new album' );
  4. >
  5. < table class = "list" cellspacing = "0" >
  6. < tr >
  7. < td colspan = "5" class = "list_title" > CDコレクション</ td >
  8. </ tr >
  9. < tr >
  10. < td class = "headers" >アルバム名</ td >
  11. < td class = "headers" >著者</ td >
  12. < td colspan = '3' class = "headers" >ジャンル</ td >
  13. </ tr >
  14. <? php
  15. foreach ($ albums_list as $ item
  16. {
  17. echo " < tr > ";
  18. echo " < td class = 'item' > "。$ item- > name。 " </ td > ";
  19. echo " < td class = 'item' > "。$ item- > author。 " </ td > ";
  20. echo " < td class = 'item' > "。$ item- > genre- > name。 " </ td > ";
  21. echo " < td class = 'item' > " .html :: anchor( 'album / delete /'.$ item- > id、html :: image(' asset / images / delete.png '))。 " </ td > ";
  22. echo " < td class = 'item' > " .html :: anchor( 'album / show_update_editor /'.$ item- > id、html :: image(' asset / images / edit.png '))。 " </ td > ";
  23. echo " </ tr > ";
  24. }
  25. >
  26. </ >
*このソースコードは、 ソースコードハイライターで強調表示されました。




ご覧のとおり、テンプレートにはアルバムのリストの出力に直接関連する情報のみが含まれています。 ただし、テンプレートだけを変更するだけでは不十分です。Album_Controllerコントローラーにアクセスする必要があります( show_albums_list()メソッドで変更を示します)。







  1. //コントローラーはTemplate_Controllerの子孫になりました!
  2. Album_ControllerクラスはTemplate_Controllerを拡張します
  3. {
  4. //ベーステンプレートを指定します
  5. public $ template = 'index';
  6. ...
  7. プライベート関数show_albums_list()
  8. {
  9. $ albums_list = $ this- > album_model- > get_list();
  10. $ this- > template- > content = View :: factory( 'list')
  11. - >セット( 'albums_list'、$ albums_list);
  12. }
  13. ...
*このソースコードは、 ソースコードハイライターで強調表示されました。




最初に、 Template_Controllerから継承しました。 つまり これで、各コントローラーに$ this->テンプレートプロパティが表示されます。これにはベーステンプレートが含まれます(コントローラーで$テンプレート変数はViewクラスのオブジェクトになります )。 さらに、デフォルトでは、この基本テンプレートは自動的に表示されます。 各メソッドの最後に$ this-> template-> render(TRUE)を呼び出す必要はなくなりました。



第二に、テンプレート(および他のオブジェクト)に好きなだけ他のパターンを配置できます。 したがって、上記の例では、 list.phpテンプレートを含む$ this->テンプレートプロパティに変数 ' content 'を設定し、変数 ' albums_list 'を渡しています。 したがって、 $ list_viewのような変数を保存する必要がなくなりました(コントローラーから削除します)。



テンプレートに変数の値を設定するには、いくつかの方法があります。 set()メソッドは、オブジェクトを順次操作する場合に便利です。この場合、呼び出しの一種のチェーンを取得します。 値を直接割り当てる( $ this-> template-> content = ... )は同じことを行いますが、読むほうがより快適です(IMHO)。




原則として、何も変更されていませんが、CSSファイルまたはナビゲーションメニューの項目のリストを変更する必要がある場合、1つのファイル( index.php )のみを編集します。



そして、あなたはアプリケーションのURLを気にしませんか?





もちろん、 localhost / kohana / index.php / albumは何とか見えません。 すべての進歩的な人類は長い間、そしてオフィスで.htaccessを使用してきました。 サイトには設定方法に関する情報があり、 config / config.phpファイルを少し調整します







  1. / **
  2. *このアプリケーションのフロントコントローラーの名前。 デフォルト:index.php
  3. *
  4. *これは、URL書き換えを使用して削除できます。
  5. * /
  6. $ config ['index_file'] = '';
*このソースコードは、 ソースコードハイライターで強調表示されました。




これで、URL内のフロントコントローラーの名前( index.php )を省略できます。 さらに、 Album_Controllerコントローラーでデフォルトのルーティングを構成します。



  // config / routes.php
 $ config ['_ default'] = 'album'; 




これで、 localhost / kohanalocalhost / kohana / index.php / albumに移動します



著者によるモデルの使用





Album_Model-> read($ id)メソッドを検討してください。これは、識別子$ idのアルバムを返すはずです:







  1. パブリック関数読み取り($ id)
  2. {
  3. $ this- > db- > where( 'id'、$ id);
  4. $ query = $ this- > db- > get($ this- > album_table);
  5. return $ query- > result_array();
  6. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




アルバムが1つしかない場合に、データベースからレコードの配列を選択する理由がわかりません。 メソッドをやり直します。







  1. パブリック関数読み取り($ id)
  2. {
  3. return $ this- > db
  4. - > where( 'id'、$ id)
  5. - >取得($ this- > album_table)
  6. - >現在();
  7. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




1つのレコードのみに関心があるため、 現在の()メソッドを使用して最初の行を取得します。 レコードが見つからない場合、 FALSEが返されます。 したがって、 show_update_editor()も変更されます(たとえば、アルバムフィールドを個別に保存する代わりに、レコード全体を保存するだけで済みます)。次のようになります。







  1. パブリック関数show_update_editor($ id)
  2. {
  3. $ album_data = $ this- > album_model- > read($ id);
  4. if(FALSE === $ album_data)
  5. イベント::実行( 'system.404');
  6. $ this- > template- > content = View :: factory( 'update')
  7. - >セット(「アルバム」、$ album_data)
  8. - > set( 'genres_list'、$ this- > get_genres_list());
  9. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




メソッドの最初に、編集されたアルバムの存在のチェックが追加され、見つからない場合、システムメッセージ ' system.404 'が生成され、対応するエラーが発生します。 見つかったアルバムに関するすべての情報は、 $ album変数としてテンプレートに保存されるため、 views / update.phpファイルも変更します。







  1. <? php echo form :: open'album / update' ); ? >
  2. < テーブル クラス = 'エディター' >
  3. < tr >
  4. < td colspan = '2' class = 'editor_title' >アルバムの更新</ td >
  5. </ tr >
  6. <? php
  7. echo " < tr > ";
  8. echo " < td > " .form :: label( 'name'、 'Name:')。 " </ td > ";
  9. echo " < td > " .form :: input( 'name'、$ album- > name)。 " </ td > ";
  10. echo " </ tr > ";
  11. echo " < tr > ";
  12. echo " < td > " .form :: label( 'author'、 'Author:')。 " </ td > ";
  13. echo " < td > " .form :: input( 'author'、$ album- > author)。 " </ td > ";
  14. echo " < tr /> ";
  15. echo " < tr > ";
  16. echo " < td > " .form :: label( 'genre'、 'Genre:')。 " </ td > ";
  17. echo " < td > " .form :: dropdown( 'genre_id'、$ genres_list、$ album- > genre_id)。 " </ td > ";
  18. echo " < tr /> ";
  19. echo " < tr > ";
  20. echo " < td colspan = '2' align = 'left' > " .form :: submit( 'submit'、 'Update album')。 " </ td > ";
  21. echo " </ tr > ";
  22. >
  23. </ >
  24. <? php
  25. echo form :: hidden'album_id' 、$ album- > id);
  26. エコー形式:: close();
  27. >
*このソースコードは、 ソースコードハイライターで強調表示されました。




ステージへのORM!





行われた変更はすべて、ほとんど表面的なものです。 ただし、 Kohanaで最も人気のあるツールの1つであるORMライブラリを表示するときが来ました。 多くの機能を備えた既製のライブラリがある場合、データベースから選択するためのさまざまなメソッドを手動で記述するのはなぜですか?



Album_ModelモデルCategories_ModelモデルORMビューに追加してみましょう。







  1. Album_ModelクラスはORMを拡張します
  2. {
  3. protected $ belongs_to = array( 'genre');
  4. }
  5. ジャンル_モデルの拡張ORM {
  6. protected $ has_many = array( 'albums');
  7. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




それだけです! さらに(今のところ)私たちのニーズには何も必要ありません。 しかし、最も興味深いのは、コントローラーでORMを使用する方法です。 アルバムのリストを表示する例を見てみましょう:







  1. プライベート関数show_albums_list()
  2. {
  3. $ albums_list = ORM :: factory( 'album')- > with( 'genre')- > find_all();
  4. $ this- > template- > content = View :: factory( 'list')
  5. - >セット( 'albums_list'、$ albums_list);
  6. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




レコードORM :: factory( 'album')-> with( 'genre')-> find_all()は、「ジャンルに関する情報とともにすべてのアルバムを選択する」、つまり アルバムジャンルテーブル間の結合が自動的に生成されます。 その結果、 ORM_Iteratorオブジェクトが返されますが、配列として操作するだけです。 ;)



実際、 with()メソッドの呼び出しをコメントアウトすると、すべてが機能します! ORMは「遅延読み込み」を実装しているため、 $ album-> genreプロパティにアクセスしようとすると、データベースに対してクエリ実行されます。 ループ内でジャンルの追加サンプルを作成するよりも、1つの結合を作成する方が簡単です。 アルバムとともに毎回手動でジャンルを選択したくない場合は、 Album_Modelに次の行を追加します。



  protected $ load_with = array( 'genre'); 




その後、ジャンルがアルバムとともに自動的に読み込まれます。





ジャンルのドロップダウンリストを生成する





覚えているように、 Album_Controllerコントローラー内のジャンルのリストを取得するために、 get_genres_list()メソッドが作成されました。







  1. プライベート関数get_genres_list()
  2. {
  3. $ db_genres_list = $ this- > genre_model- > get_list();
  4. $ genres_list = array();
  5. if(sizeof($ db_genres_list) > = 1)
  6. {
  7. foreach($アイテムとしてのdb_genres_list)
  8. {
  9. $ genres_list [$ item- > id] = $ item- > name;
  10. }
  11. }
  12. return $ genres_list;
  13. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




魔法の杖を振ると、メソッドは1行に変わります。







  1. プライベート関数get_genres_list()
  2. {
  3. return ORM :: factory( 'genre')- > find_all()- > select_list( 'id'、 'name');
  4. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




ORMオブジェクトの作成と編集





最後に、最もおいしい。 create()およびupdate()メソッドはチェックを実行せず、入力されたデータをAlbum_Modelモデルにスリップしようとするだけです。 しかし、 KohanaにORMで使用するのに非常に便利な素晴らしい検証ライブラリがあります!



まず、 Album_Modelモデルに数行を追加します。







  1. パブリック関数の検証(配列&$配列、$ save = FALSE)
  2. {
  3. $ array = Validation :: factory($配列)
  4. - > pre_filter( 'トリム')
  5. - > add_rules(「名前」、「必須」)
  6. - > add_rules(「作成者」、「必須」)
  7. - > add_rules( 'genre_id'、 'required')
  8. - > add_callbacks( 'name'、array($ this、 '_album_available'));
  9. 親を返す:: validate($配列、$ save);
  10. }
  11. public function _album_available(検証$配列、$フィールド){
  12. $ result =(bool)! $ this- > db
  13. - > where(array( 'name' = > $ array ['name']、 'author' = > $ array ['author']、 'id!=' = > $ this- > id))
  14. - > count_records($ this- > table_name);
  15. if(!$ result)$ array- > add_error($ field、 'album_exists');
  16. return $ result;
  17. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




これは、検証ライブラリを使用して入力されたデータを検証するvalidate()メソッドと、アルバムとアーティストの組み合わせの一意性を処理する非標準ルール(より正確には、 コールバック )を処理します 。 それらの使用は非常に簡単です。修正されたcreate()メソッドを検討してください。







  1. パブリック関数create()
  2. {
  3. if($ this- > input- > post())
  4. {
  5. $データ=配列
  6. 'name' = > NULL、
  7. 'author' = > NULL、
  8. 'genre_id' = > NULL
  9. );
  10. $ data = arr :: overwrite($ data、$ this- > input- > post());
  11. $ album = ORM :: factory( 'album');
  12. if($ album- > validate($ data、TRUE)){
  13. url ::リダイレクト( 'アルバム');
  14. }
  15. その他{
  16. Session :: instance()- > set( 'errors'、$ data- > errors( 'album'));
  17. セッション::インスタンス()- > set( 'data'、$ data- > as_array());
  18. }
  19. }
  20. url :: redirect( 'album / show_create_editor');
  21. }
*このソースコードは、 ソースコードハイライターで強調表示されました。




$ _POSTのデータの可用性を順番に確認し、対象のフィールドを$ data配列にロードし(このためにarrヘルパーoverwrite()メソッドを使用)、検証のためにvalidate()メソッドに送信しました。 TRUEに設定された2番目のパラメーターは、検証が成功した場合、 ORMオブジェクトが保存されることを意味します。 検証エラーが発生した場合、エラーの説明と現在の値をセッションのフォームから保存し(小さなタイプミスのために多数のフォームフィールドを再び運転するのは本当に好きではありません)、エディターにリダイレクトします。 したがって、 show_create_editor()メソッドとそのテンプレート( create.php )を変更する必要があります。







  1. パブリック関数show_create_editor()
  2. {
  3. $ errors = Session :: instance()- > get_once( 'errors'、array());
  4. $ data = array( 'name' = > ''、 'author' = > '' '、' genre_id '= > ' ');
  5. $ data = arr :: overwrite($ data、Session :: instance()- > get_once( 'data'、array()));
  6. $ genres_list = $ this- > get_genres_list();
  7. $ this- > template- > content = View :: factory( 'create')
  8. - >設定(「genres_list」、$ genres_list)
  9. - >設定(「エラー」、$エラー)
  10. - > set( 'data'、$ data);
  11. }
*このソースコードは、 ソースコードハイライターで強調表示されました。








  1. <? php echo form :: open'album / create' ); ? >
  2. <? php foreach ($ エラー として $ エラー
  3. echo " < div class = 'error' > "。$ error。 " </ div > " ;? >
  4. < テーブル クラス = 'エディター' >
  5. < tr >
  6. < td colspan = '2' class = 'editor_title' >新しいアルバムを作成</ td >
  7. </ tr >
  8. <? php
  9. echo " < tr > ";
  10. echo " < td > " .form :: label( 'name'、 'Name:')。 " </ td > ";
  11. echo " < td > " .form :: input( 'name'、$ data ['name'])。 " </ td > ";
  12. echo " </ tr > ";
  13. echo " < tr > ";
  14. echo " < td > " .form :: label( 'author'、 'Author:')。 " </ td > ";
  15. echo " < td > " .form :: input( 'author'、$ data ['author'])。 " </ td > ";
  16. echo " < tr /> ";
  17. echo " < tr > ";
  18. echo " < td > " .form :: label( 'genre'、 'Genre:')。 " </ td > ";
  19. echo " < td > " .form :: dropdown( 'genre_id'、$ genres_list、$ data ['genre_id'])。 " </ td > ";
  20. echo " < tr /> ";
  21. echo " < tr > ";
  22. echo " < td colspan = '2' align = 'left' > " .form :: submit( 'submit'、 'C​​reate album')。 " </ td > ";
  23. echo " </ tr > ";
  24. >
  25. </ >
  26. <? PHP エコー フォーム:: close (); ? >
*このソースコードは、 ソースコードハイライターで強調表示されました。




このメソッドの変更のほとんどは、セッションからデータを取得し、ユーザーに表示するためにテンプレートにデータを代入する試みです。 エラーはフォームの最初に表示されますが、対応する入力フィールドの前にエラーを表示する人はいません。 同様の変更をupdate()show_update_redactor()メソッド、およびupdate.phpテンプレートに対して行う必要があります。



検証エラー出力





create()メソッドの17行目の$ data-> errors( 'album')メソッドに注目してください。 配列にとってはちょっと変ですよね? 実際には、 $データ配列がvalidate()メソッドに渡されると、 Validationオブジェクトになります。 そして、既にその中に検証エラーを返すerror()メソッドがあります。 i18nファイルの名前を転送すると、指定されたファイルを使用してエラーが翻訳されます。 考えられるエラーを翻訳しましょう:







  1. //ファイルi18n / ru_RU / album.php
  2. <? 定義済みの php'SYSPATH'または die'直接スクリプトアクセスなし' );
  3. $ lang = array
  4. 'name' = >配列(
  5. 'required' = > 'アルバム名が指定されていません'、
  6. 'album_exists' = > 'アルバム+アーティストの組み合わせは既に追加されています'、
  7. )、
  8. 'author' = >配列
  9. '必須' = > 'アーティスト名が指定されていません'、
  10. )、
  11. 'genre_id' = >配列
  12. '必須' = > 'アルバムのジャンルが選択されていません'、
  13. )、
  14. );
*このソースコードは、 ソースコードハイライターで強調表示されました。








  1. //ファイルi18n / en_US / album.php
  2. <? 定義済みの php'SYSPATH'または die'直接スクリプトアクセスなし' );
  3. $ lang = array
  4. 'name' = >配列(
  5. '必須' = > 'アルバム名が必要です'、
  6. 'album_exists' = > 'アルバムとアーティストの組み合わせは既に存在します'、
  7. )、
  8. 'author' = >配列
  9. '必須' = > '著者名が必要です'、
  10. )、
  11. 'genre_id' = >配列
  12. 'required' = > 'Genre required'、
  13. )、
  14. );
*このソースコードは、 ソースコードハイライターで強調表示されました。




2つのファイルを作成しました。ロシア語と英語で、テキストリソースはフォームフィールド名でグループ化されています。 アプリケーションでデフォルトで使用されるファイルを推測しますか? もちろん、英語。 locale.phpファイルsystem / configフォルダーからコピーし、ロシア語の値を修正します。







  1. <? php定義(「SYSPATH」)またはダイ(「直接アクセス不可」);
  2. / **
  3. * @package Core
  4. *
  5. *デフォルトの言語ロケール名。
  6. *最初の項目は有効な国際化ディレクトリ名である必要があり、後続の項目は代替ロケールです
  7. *最初のものをサポートしていないOS(Windowsなど)の場合。 配列内の最初の有効なロケールが使用されます。
  8. * @see php.net/setlocale
  9. * /
  10. $ config ['language'] = array( 'ru_RU'、 'Russian_Russia');
  11. / **
  12. *ロケールのタイムゾーン。 サーバーのタイムゾーンを使用するデフォルト。
  13. * @see php.net/timezones
  14. * /
  15. $ config ['timezone'] = '';
*このソースコードは、 ソースコードハイライターで強調表示されました。




まとめ





それは私が言ったすべての主要なポイントのようです。 NetTutsプロジェクトに変更を加えてみてください。そうなった場合は 、私が手に入れたアーカイブを覗くことができます。 もちろん、ささいなこと(特定のアーティストやジャンルによる並べ替え、選択)が十分に多くあるわけではありませんが、これはこの記事の枠組みの中で非現実的です。 独立して作業したい場合は、アーティストを別のテーブルに配置することもできます。これには、コントローラーとテンプレートを変更するための手間がかかります。






All Articles