このトピックでは、データベーステーブルのコンテンツを編集する例を使用して、ExtJSフレームワークとphp Zend Frameworkのjavascriptコンポーネントを操作する方法について説明します。
コンテンツ要素のリストを編集するには、個別のインスタンスであるFormPanelにExtJS GridPanelコンポーネントを使用します。
このレビューは、指定されたフレームワークを備えたロボットの基本を知っている人向けに設計されています。データベース接続の作成、ブートローダーの作成など、詳細については触れません。
開発には、ExtJS 3.0、Zend Framework 1.8.1を使用しました。
Db
最初に、データベースにテーブルを作成します。
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
CREATE TABLE `articles` ( `id` int ( 11 ) NOT NULL AUTO_INCREMENT , `title` varchar ( 255 ) , `shorttext` text , `createdate` datetime , `text` text , PRIMARY KEY ( `id` ) ) ;
この例では、ニュースフィードになります。テーブルには、見出し、日付、短いテキスト、フルテキストのフィールドがあります。
グリッドパネル
Zend Frameworkライブラリを使用してデータを操作するためのインターフェースを作成します。
新しいhtmlページを作成します。 必要なものすべて、css、ExtJSを接続します。
- var record = Ext。 データ 記録します。 作成 ( [
- { 名前 : 'id' 、タイプ: 'int' } 、
- { 名前 : 'タイトル' } 、
- { 名前 : 「createdate」 、タイプ: 「date」 、 dateFormat : 「Ymd h:i:s」 } 、
- ] ) ;
- var ds = 新しい内線 データ ストア ( {
- remoteSort : false 、
- プロキシ: 新しい内線 データ HttpProxy ( {
- url : '/ grid / grid /'
- } ) 、
- リーダー: 新しい Ext。 データ JsonReader ( {
- ルート: 'result' 、
- totalProperty : 'totalCount'
- } 、記録)
- } ) ;
- paddingBar = new Ext。 PagingToolbar ( {
- pageSize : 10 、
- ストア: ds 、
- displayInfo : true 、
- displayMsg : '{2}のトピック{0}-{1}を表示しています' 、
- emptyMsg : 「表示するトピックはありません」
- } ) ;
- var renderDate = function ( value 、 p 、 record ) {
- 戻り値。 format ( "j / n / YH:i:s" ) ;
- } ;
- var grid = new Ext。 グリッド GridPanel ( {
- ストア: ds 、
- trackMouseOver : false 、
- loadMask : true 、
- 列: [ {
- id : 'id' 、
- ヘッダー: 「Id」 、
- dataIndex : 'id' 、
- 幅: 40 、
- ソート可能: true
- } 、 {
- ヘッダー: 「タイトル」 、
- dataIndex : 'title' 、
- 幅: 300 、
- ソート可能: true
- } 、 {
- ヘッダー: "Createdate" 、
- dataIndex : 'createdate' 、
- 幅: 200 、
- レンダラー: renderDate 、
- ソート可能: true
- } ] 、
- tbar : [
- 新しい内線 ボタン ( {
- テキスト: 「新規」 、
- ハンドラー: addRecord
- } ) 、
- 新しい内線 ボタン ( {
- テキスト: 「編集」 、
- ハンドラー: editRecord
- } ) 、
- 新しい内線 ボタン ( {
- テキスト: 「削除」 、
- ハンドラー: deleteRecords
- } ) 、
- ] 、
- bbar : paddingBar
- } ) ;
- グリッド。 on ( "rowdblclick" 、 editRecord ) ;
- var window = new Ext。 ウィンドウ ( {
- id : 'example-window' 、
- title : "グリッドの例" 、
- レイアウト: 'fit' 、
- 幅: 800 、
- 高さ: 400 、
- アイテム: [グリッド]
- } ) ;
- ウィンドウ。 show ( ) ;
- グリッド。 getStore ( ) 。 ロード ( ) ;
コードに関するコメント:
必須フィールドの定義を使用してレコードを作成します。 名前と形式は、データベーステーブルのフィールドに対応する必要があります(1〜5)。 データをロードするコントローラーのURLを指定します(/ grid / grid /)。 結果にはテーブルエントリが含まれます。 totalCountのページをナビゲートできるようにするには、エントリの総数を指定する必要があります。 ページナビゲーション用に、ExtJSライブラリはExt.PagingToolbarコンポーネント(16-22)を提供します。 10個のエントリがページに表示されることを示します。
日付のレンダリング-表示に便利な形式で表示します(23-25)。
コンテンツを追加、編集、削除するには、ツールバーにボタンを追加する必要があります(48-61)。
テーブル内のエントリをダブルクリックするための別のハンドラーが追加されました。 コンテンツを選択してから、ボタンをクリックして編集するのは不便です(64)。
テーブルがウィンドウに表示されます(65-73)。 最後に、データをテーブルにロードします(74)。
結果は次のようになります。
グリッドコントローラー
phpに渡して、クライアント部分とやり取りするコントローラーを作成します。
- クラス GridController は Zend_Controller_Actionを拡張します
- {
- ...
- }
モデルを作成してみましょう。テーブル内のレコードの合計数を返すメソッドを1つ追加しました(フレームワークでは、これを行う標準関数は見つかりませんでした)。
- クラスグリッドは Zend_Db_Table_Abstractを拡張します
- {
- パブリック 関数 getCountRows ( )
- {
- $ select = $ this- > select ( ) -> from ( array ( 'p' => $ this- > _name ) 、 array ( 'c' => 'COUNT(*)' ) ) ;
- $ stmt = $ select- > query ( ) ;
- $ result = $ stmt- > fetchAll ( ) ;
- return $ result [ 0 ] [ 0 ] ;
- }
- }
テーブルにデータをロードするグリッドコントローラーのメソッド。
- パブリック 関数 gridAction ( )
- {
- $ this- > _helper- > viewRenderer- > setNoRender ( ) ;
- require_once 'Grid.php' ;
- $ grid = new Grid ( array ( 'name' => 'articles' ) ) ;
- $ totalCount = $ grid- > getCountRows ( ) ;
- $ where = null ;
- $ order = "id" ;
- $ limit = $ this- > getRequest ( ) -> getParam ( 'limit' 、 5 ) ;
- $ start = $ this- > getRequest ( ) -> getParam ( 'start' 、 0 ) ;
- $ rows = $ grid- > fetchAll ( $ where 、 $ order 、 $ limit 、 $ start ) ;
- $データ = 配列 (
- 'totalCount' => $ totalCount 、
- 'result' => $ rows- > toArray ( )
- ) ;
- echo json_encode ( $ data ) ;
- }
このメソッドでは、レコードの総数を見つけてページを選択します。 ページナビゲーションでは、開始値と制限値もパラメーターとして渡されます。 要素とデータの総数で配列を作成し、JSON形式に変換します。 ラッパーを使用せずにヘルパーを使用するか、通常の関数を使用できます。
2番目の部分では、データを編集するためのフォームの作成、編集用のコントローラーの作成、およびデータの削除方法を検討します。