fc2ブログ

記事一覧

多階層構造のリピーターコントロールにデータバインドする方法 -How to bind multilayer dataset to repeater- | asp.net


今回は asp.net の サーバーコントロール Repeater において 親子関係を保持する多階層構造を表現する方法についてご紹介いたします。
GrapeCity の SPREAD ではバインドするだけで容易に多階層構造を表現することができましたが、asp.net の通常の Repeater コントロールでは少し設定をしないと多階層の表現をすることはできませんでした。


aspnet_repeater_multilayer_01.png


前提条件
・Windows 7 Professional 以降 / Windows Server 2008 R2 以降
・Visual Studio 2010 Professional 以降
・VB.NET
・.Net Framework 4.0 以降



1.DataSet の構成方法

前回の記事「データセットに複数列のリレーションを追加する方法」にて 多階層構造を表現するためのデータセットの設定方法についてご紹介していますので、ご参考ください。



2.プロパティの実装

親子関係のデータビューを取得するためのプロパティを実装します。

DataSetTest.vb
Option Explicit On
Option Strict On
Public Class DataSetTest
Inherits System.Web.UI.Page

Protected ReadOnly Property GetChildRelation(ByVal dataItem As Object, ByVal relation As String) As DataView
Get
Dim drv As DataRowView = DirectCast(dataItem, DataRowView)
If drv IsNot Nothing Then

Return drv.CreateChildView(relation)
Else
Return Nothing
End If
End Get
End Property

Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

'以前の記事でご紹介していますので、省略します。

End Sub

End Class



3.Repeater の実装方法

Repeater の内部にさらに Repeater を追加していき、親子孫の多階層構造となる多段 Repeater を実装します。
リピーターには以下のデータソース設定を追加することが必要なポイントとなります。
DataSource='<%# GetChildRelation(Container.DataItem, "リレーション名")%>'

aspnet_repeater_multilayer_02.png


DataSetTest.aspx
<%@ Page Language="vb" AutoEventWireup="false" CodeBehind="DataSetTest.aspx.vb" Inherits="AspNetTest.DataSetTest" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>DataSetTest</title>
<link rel="stylesheet" type="text/css" href="~/Styles/Style.css" media="all" />
<script src="Scripts/jquery-1.10.2.min.js"></script>
</head>
<body>
<form id="form1" runat="server">
<div>

<%-- 親階層 --%>
<asp:Repeater ID="rptLargeCategory" runat="server">
<ItemTemplate>
<ul>
<li>
<asp:Label ID="lblCode" runat="server" Text='<%# Eval("LargeCode") %>' />
:
<asp:Label ID="lblName" runat="server" Text='<%# Eval("LargeName") %>' />
</li>

<%-- 子階層 --%>
<asp:Repeater ID="rptMiddleCategory" runat="server" DataSource='<%# GetChildRelation(Container.DataItem, "Category_Large-Middle")%>'>
<ItemTemplate>
<ul>
<li>
<asp:Label ID="lblCode" runat="server" Text='<%# Eval("MiddleCode") %>' />
:
<asp:Label ID="lblName" runat="server" Text='<%# Eval("MiddleName") %>' />
</li>

<%-- 孫階層 --%>
<asp:Repeater ID="rptSmallCategory" runat="server" DataSource='<%# GetChildRelation(Container.DataItem, "Category_Middle-Small")%>'>
<ItemTemplate>
<ul>
<li>
<asp:Label ID="lblCode" runat="server" Text='<%# Eval("SmallCode") %>' />
:
<asp:Label ID="lblName" runat="server" Text='<%# Eval("SmallName") %>' />
</li>
</ul>
</ItemTemplate>
</asp:Repeater>

</ul>
</ItemTemplate>
</asp:Repeater>

</ul>
</ItemTemplate>
</asp:Repeater>

</div>
</form>
</body>
</html>


以上で 多階層構造のリピーターコントロールにデータバインドできます。





最後までお読みいただきありがとうございます。
いかがでしたでしょうか。他にも asp.net に関連する記事を投稿しておりますのでよろしければご参考くださいませ。




関連記事

コメント

コメントの投稿

※名前とタイトルが入力されていないコメントでは他のコメントとの区別ができません。

 入力されていないコメントには返信しませんのであらかじめご了承くださいませ。

※ニックネームでも良いので必ずご入力ください。

    

※必ずご入力ください。

    
    

※必ずご入力ください。

※技術的な質問には環境やエラーについて正確かつ詳細にお教えください。

・正確なエラーの内容

・Windowsのバージョン番号

・Visual Studioのバージョン

・機器の型番

・アプリやソフトのバージョン

    

カテゴリ別記事一覧

広告

プロフィール

石河 純


著者名 :石河 純
自己紹介:素人上がりのIT技術者。趣味は卓球・車・ボウリング

IT関連の知識はざっくりとこんな感じです。
【OS関連】
WindowsServer: 2012/2008R2/2003/2000/NT4
Windows: 10/8/7/XP/2000/me/NT4/98
Linux: CentOS RedHatLinux9
Mac: macOS Catalina 10.15 / Mojave 10.14 / High Sierra 10.13 / Sierra 10.12 / OSX Lion 10.7.5 / OSX Snow Leopard 10.6.8
【言語】
VB.net ASP.NET C#.net Java VBA
Xamarin.Forms
【データベース】
Oracle 10g/9i
SQLServer 2016/2008R2/2005/2000
SQLAnywhere 16/11/8
【BI/レポートツール】
Cognos ReportNet (IBM)
Microsoft PowerBI
ActiveReport (GrapeCity)
CrystalReport
【OCX関連】
GrapeCity InputMan SPREAD MultiRow GridView
【ネットワーク関連】
CCNP シスコ技術者認定
Cisco Catalyst シリーズ
Yamaha RTXシリーズ
FireWall関連
【WEB関連】
SEO SEM CSS jQuery IIS6/7 apache2

休みの日は卓球をやっています。
現在、卓球用品通販ショップは休業中です。