ASP.NET树视图填充子节点。如何避免回发到服务器?

ASP.NET树视图填充子节点。如何避免回发到服务器?,asp.net,treeview,Asp.net,Treeview,我正在尝试测试一个树视图的按需填充。 我遵循以下链接中的程序: 但是,如果我扩展了其中一个树节点(如果您在Page_load事件的第一行中放置断点),那么treeview仍然会向服务器回发,从而刷新整个页面。我使用的是VS2005和Asp.net 2.0(但在VS2008中也会出现同样的问题) 我的简单测试页标记是: <%@ Page Language="C#" AutoEventWireup="true" CodeFile="aspTreeview.aspx.cs" Inherits=

我正在尝试测试一个树视图的按需填充。 我遵循以下链接中的程序:

但是,如果我扩展了其中一个树节点(如果您在Page_load事件的第一行中放置断点),那么treeview仍然会向服务器回发,从而刷新整个页面。我使用的是VS2005和Asp.net 2.0(但在VS2008中也会出现同样的问题)

我的简单测试页标记是:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="aspTreeview.aspx.cs" Inherits="aspTreeview" %>

<!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>Untitled Page</title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <table>
            <tr>
                <td style="height: 80%; width: 45%;">
                    <asp:Panel ID="Panel1" runat="server" BorderColor="#0033CC" BorderStyle="Solid" ScrollBars="Both">
                        <asp:TreeView ID="TreeView1" runat="server" ShowLines="True" PopulateNodesFromClient="True" EnableClientScript="True" NodeWrap="True" 
                            ontreenodepopulate="TreeView1_TreeNodePopulate" ExpandDepth="0">
                        </asp:TreeView>
                    </asp:Panel>
                </td>
                <td style="width: 10%; height: 80%;" >
                    <div>
                    <asp:Button ID="Button1" runat="server" Text="->" onclick="Button1_Click" />
                    </div>
                    <div>
                    <asp:Button ID="Button2" runat="server" Text="<-" />
                    </div>
                </td>
                <td style="width: 136px; height: 80%">
                    <asp:Panel ID="Panel2" runat="server" BorderColor="Lime" BorderStyle="Solid">
                        <asp:TreeView ID="TreeView2" runat="server" ShowLines="True" ExpandDepth="0">
                        </asp:TreeView>
                    </asp:Panel>
                </td>
            </tr>
            <tr>
                <td>
                </td>
                <td>
                </td>
                <td style="width: 136px">
                </td>
            </tr>
        </table>
    </div>
    </form>
</body>
</html>

无标题页
背后的代码是:

protected void Page_Load(object sender, EventArgs e)
{
    Debug.WriteLine("Page_Load started.");
    if (!IsPostBack)
    {
        if (Request.Browser.SupportsCallback)
            Debug.WriteLine("Browser supports callback scripts.");
        for (int i = 0; i < 3; i++)
        {
            TreeNode node = new TreeNode("ENTRY " + i.ToString());
            node.Value = i.ToString();
            node.PopulateOnDemand = true;
            node.Expanded = false;
            TreeView1.Nodes.Add(node);
        }
    }
    Debug.WriteLine("Page_Load finished.");
}

protected void TreeView1_TreeNodePopulate(object sender, TreeNodeEventArgs e)
{
    TreeNode targetNode = e.Node;
    for (int j = 0; j < 4200; j++)
    {
        TreeNode subnode = new TreeNode(String.Format("Sub ENTRY {0} {1}", targetNode.Value, j));
        subnode.PopulateOnDemand = true;
        subnode.Expanded = false;
        targetNode.ChildNodes.Add(subnode);
    }
}
受保护的无效页面加载(对象发送方,事件参数e)
{
Debug.WriteLine(“页面加载已启动”);
如果(!IsPostBack)
{
if(Request.Browser.SupportsCallback)
WriteLine(“浏览器支持回调脚本”);
对于(int i=0;i<3;i++)
{
TreeNode=新的TreeNode(“条目”+i.ToString());
node.Value=i.ToString();
node.PopulateOnDemand=true;
node.Expanded=false;
TreeView1.Nodes.Add(节点);
}
}
Debug.WriteLine(“页面加载完成”);
}
受保护的无效树视图1_TreeNodePopulate(对象发送器,TreeNodeEventArgs e)
{
TreeNode targetNode=e.节点;
对于(int j=0;j<4200;j++)
{
TreeNode子节点=新的TreeNode(String.Format(“子条目{0}{1}”,targetNode.Value,j));
subnode.PopulateOnDemand=true;
扩展的子节点=false;
targetNode.ChildNodes.Add(子节点);
}
}

runat=“server”
更改为
runat=“client”
页面加载被调用,但它不是完整的回发,因为不必重新加载整个页面。有关更多信息,请参阅此答案:

没有选项客户端,它是一个服务器控件