DevExpress の ASPxGridView でのデータ取得(N項目)のサンプルです。
今回は、グリッド行のダブルクリックイベントで、
選択行のデータ(N項目)を取得します。
設定する内容は2点です。
1点目:「AllowFocusedRow」のフォーカス行を「有効」
2点目:「ASPxGridView」の「RowDblClick」行ダブルクリックイベントにデータ取得を指示
現状の画面デザインはこのようになっています。
「ASPxGridView」オブジェクトのプロパティを変更していきます。
※プロパティ画像は「グループ表示」
<データ取得(N項目)>
1点目:「AllowFocusedRow」のフォーカス行を「有効」
「AllowFocusedRow=”True”」に変更します。
↓
2点目:「ASPxGridView」の「RowDblClick」行ダブルクリックイベントにデータ取得を指示
「RowDblClick」を選択し「ClickGetFocusedRow();」を指示します。
※「ClickGetFocusedRow」はローカルメソッドです。
※DevExpress を 「V13.2」から「V15.1」へアップデートしたため、
今までの画像と大きく画面デザインが変わっています。
↓
- ASPxGridViewからデータ取得します。(GetRowValues)
第一引数:取得対象行(インデックス:選択行インデックス取得(GetFocusedRowIndex))
第二引数:取得対象項目(カラム)
※セミコロン「;」で複数項目を指示します。
第三引数:取得後の処理関数(メソッド:OnGetRowValues)
※「GetRowValues」は非同期なので、第三引数で処理関数を渡す必要があります。
※「OnGetRowValues」はローカルメソッドです。
- データ取得後の指示をします。(OnGetRowValues)
第一引数:取得データ
※「OnGetRowValues」はローカルメソッドです。
※「values」はローカル配列変数です。
【生成PG】
1 2 3 4 5 6 7 8 |
<script type="text/javascript"> function ClickGetFocusedRow() { grid.GetRowValues(grid.GetFocusedRowIndex(), '地方名;都道府県名;県庁所在地名', OnGetRowValues); } function OnGetRowValues(values) { alert("「" + values[0] + "」地方「" + values[1] + "」「" + values[2] + "」市を選択"); } </script> |
【自動生成PG】
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 |
<script type="text/javascript"> function ClickGetFocusedRow() { grid.GetRowValues(grid.GetFocusedRowIndex(), '地方名;都道府県名;県庁所在地名', OnGetRowValues); } function OnGetRowValues(values) { alert("「" + values[0] + "」地方「" + values[1] + "」「" + values[2] + "」市を選択"); } </script> <form id="form1" runat="server"> <div> <dx:ASPxGridViewExporter ID="ASPxGridViewExporter1" runat="server" GridViewID="ASPxGridView1" FileName="都道府県一覧" BottomMargin="10" Landscape="True" LeftMargin="10" RightMargin="10" TopMargin="10" ExportedRowType="Selected"> <Styles> <Default Font-Names="MS ゴシック" Wrap="False"> <Paddings Padding="10px" /> </Default> <Header BackColor="#F479A5" ForeColor="#FFECFF"> </Header> <AlternatingRowCell BackColor="#F8EEEF"> </AlternatingRowCell> </Styles> </dx:ASPxGridViewExporter> <asp:AccessDataSource ID="AccessDataSource1" runat="server" DataFile="~/App_Data/TestDB.mdb" SelectCommand="SELECT * FROM [県名]" DeleteCommand="DELETE FROM [県名] WHERE [ID] = ?" InsertCommand="INSERT INTO [県名] ([地方名], [都道府県名], [都道府県めい], [都道府県MEI], [県庁所在地名], [県庁所在地めい]) VALUES (?, ?, ?, ?, ?, ?)" UpdateCommand="UPDATE [県名] SET [地方名] = ?, [都道府県名] = ?, [都道府県めい] = ?, [都道府県MEI] = ?, [県庁所在地名] = ?, [県庁所在地めい] = ? WHERE [ID] = ?"> <DeleteParameters> <asp:Parameter Name="ID" Type="Int32" /> </DeleteParameters> <InsertParameters> <asp:Parameter Name="地方名" Type="String" /> <asp:Parameter Name="都道府県名" Type="String" /> <asp:Parameter Name="都道府県めい" Type="String" /> <asp:Parameter Name="都道府県MEI" Type="String" /> <asp:Parameter Name="県庁所在地名" Type="String" /> <asp:Parameter Name="県庁所在地めい" Type="String" /> </InsertParameters> <UpdateParameters> <asp:Parameter Name="地方名" Type="String" /> <asp:Parameter Name="都道府県名" Type="String" /> <asp:Parameter Name="都道府県めい" Type="String" /> <asp:Parameter Name="都道府県MEI" Type="String" /> <asp:Parameter Name="県庁所在地名" Type="String" /> <asp:Parameter Name="県庁所在地めい" Type="String" /> <asp:Parameter Name="ID" Type="Int32" /> </UpdateParameters> </asp:AccessDataSource> <dx:ASPxGridView ID="ASPxGridView1" runat="server" AutoGenerateColumns="False" DataSourceID="AccessDataSource1" KeyFieldName="ID" Theme="RedWine" Width="100%" ClientInstanceName="grid"> <Columns> <dx:GridViewCommandColumn ShowClearFilterButton="True" VisibleIndex="0" FixedStyle="Left" Visible="False"> <CellStyle Wrap="False" BackColor="#FFCCCC"> </CellStyle> </dx:GridViewCommandColumn> <dx:GridViewDataTextColumn FieldName="ID" ReadOnly="True" VisibleIndex="1" Visible="False"> <EditFormSettings Visible="False" /> </dx:GridViewDataTextColumn> <dx:GridViewDataTextColumn FieldName="地方名" VisibleIndex="2"> </dx:GridViewDataTextColumn> <dx:GridViewBandColumn Caption="都道府県" VisibleIndex="8"> <Columns> <dx:GridViewDataTextColumn FieldName="都道府県名" VisibleIndex="0"> </dx:GridViewDataTextColumn> <dx:GridViewDataTextColumn FieldName="都道府県めい" VisibleIndex="1"> </dx:GridViewDataTextColumn> <dx:GridViewDataTextColumn FieldName="都道府県MEI" VisibleIndex="2"> <Settings AutoFilterCondition="Contains" HeaderFilterMode="CheckedList" /> </dx:GridViewDataTextColumn> </Columns> <HeaderStyle HorizontalAlign="Center" /> </dx:GridViewBandColumn> <dx:GridViewBandColumn Caption="県庁所在地" VisibleIndex="9"> <Columns> <dx:GridViewDataTextColumn FieldName="県庁所在地名" VisibleIndex="0"> </dx:GridViewDataTextColumn> <dx:GridViewDataTextColumn FieldName="県庁所在地めい" VisibleIndex="1" Width="120px"> </dx:GridViewDataTextColumn> </Columns> <HeaderStyle HorizontalAlign="Center" /> </dx:GridViewBandColumn> </Columns> <SettingsBehavior AutoFilterRowInputDelay="15000" AllowSelectSingleRowOnly="True" AllowFocusedRow="True" /> <ClientSideEvents RowDblClick="function(s, e) { ClickGetFocusedRow(); }" /> <SettingsPager Position="TopAndBottom"> <AllButton Visible="True"> </AllButton> <FirstPageButton Visible="True"> </FirstPageButton> <LastPageButton Visible="True"> </LastPageButton> <Summary Position="Right" /> <PageSizeItemSettings Items="5, 10, 15, 20, 25, 30, 35, 40, 45, 50" Visible="True"> </PageSizeItemSettings> </SettingsPager> <Settings ShowGroupedColumns="True" ShowGroupPanel="True" ShowFilterRow="True" ShowHeaderFilterButton="True" ShowStatusBar="Hidden" /> <Styles> <AlternatingRow Enabled="True"> </AlternatingRow> </Styles> </dx:ASPxGridView> </div> </form> |
↓
実行すると画面が表示されます。
↓
「青森県」の行をダブルクリックします。
「ASPxGridView」から選択したN項目のデータ(〜青森県〜)がメッセージ表示されました。
- 投稿タグ
- ASPxGridView, JavaScript