0

Teleriks RadTreeView コントロールの AppendDataBoundItems プロパティを使用すると、静的な値とともにデータをバインドできます。

あなたの木は次のように見えるかもしれません

  • 静的アイテム A
  • 静的アイテム B
  • 静的アイテム C
  • データバインドされたアイテム A
  • データバインドされたアイテム B
  • データバインドされたアイテム C

しかし、私はすべてのバインドされた値を特定のノードの下に置きたいです。

  • 静的アイテム A
  • 静的アイテム B
  • 静的アイテム C
    • データバインドされたアイテム A
    • データバインドされたアイテム B
    • データバインドされたアイテム C

データを操作してこの効果を実現できることはわかっていますが、ストアド プロシージャに UI コードを移動するのは苦手です。

他に方法はありますか?

4

2 に答える 2

1

ストアドプロシージャに、ツリービューにバインドするデータセットにデータを返してもらいます。データセットを取り戻したら、データセットに保持されているデータを操作し、変更したデータセットをツリービューにバインドします。ストアドプロシージャはまだデータバインドされたデータを返しているので、man-in-the-middleをプレイしています。

于 2011-09-16T17:33:20.443 に答える
0

これは不可能だと思い始めたので、自分でアイテムを追加しました。

これを行う方法を探している他の人への将来の参照のために、ここに手動の方法があります。

Default2.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default2.aspx.cs" Inherits="TelerikTreetoProc._Default2" %>
<%@ Register assembly="Telerik.Web.UI" namespace="Telerik.Web.UI" tagprefix="telerik" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:ScriptManager ID="scriptManager1" runat="server" />
        <telerik:RadTreeView ID="treeSideBarCommands" Runat="server">
            <Nodes>
                <telerik:RadTreeNode runat="server" Text="Static Item A" />
                <telerik:RadTreeNode runat="server" Text="Static Item B" />
                <telerik:RadTreeNode runat="server" Text="Static Item C"/>
            </Nodes>
        </telerik:RadTreeView>
    </div>
    </form>
</body>
</html>

そして私のコードビハインドファイルは

using System;
using System.Data;
using System.Data.SqlClient;
using System.Web.Configuration;
using Telerik.Web.UI;

namespace TelerikTreetoProc
{
    public partial class _Default2 : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            string sql = "select EmployeeID, FirstName + LastName [name] from Employees";
            string connString = WebConfigurationManager.ConnectionStrings["NorthwindConnectionString"].ConnectionString;
            using(var cn = new SqlConnection(connString ))
            using(var cmd = new SqlCommand( sql, cn))
            {
                cn.Open();
                cmd.CommandType = CommandType.Text;
                SqlDataReader dr = cmd.ExecuteReader();
                RadTreeNode nd = treeSideBarCommands.Nodes[2];
                while (dr.Read())
                {
                    nd.Nodes.Add(new RadTreeNode(dr[1].ToString(), dr[0].ToString()));
                }
            }
        }
    }
}
于 2011-09-16T18:30:18.690 に答える