在treeview中,我想实现pageload的时候只加载父节点(因为我的父节点至少有200个)。然后再点击每个父节点的时候触发事件,加载该父节点下的子节点(每个父节点下的子节点也有好几十个)。
现在我想用asp。net语言来实现。
可是我搜了很多都没有合适的代码。
主要有两个问题。
1。如何实现我上面所说的分级加载的功能。
2。点击节点事件会使整个tree闪动重加载(autopost=true),能不能不让他重加载,只添加点击的子节点内容。

解决方案 »

  1.   

    希望大家给出具体的demo。越详细越好,解决就给分!!
      

  2.   

    /// <summary>
    /// 生成菜系节点
    /// </summary>
    /// <param name="ParentID">父节点id</param>
    /// <param name="treeNode">节点树对象</param>
    private void BindTreeView(string ParentID,TreeNodeCollection treeNode)
    {
    DataTable dt= Rule.Tree(wuser); 
    DataView dvTree = new DataView(dt);
    dvTree.RowFilter =  "nvrParentCode = '" + ParentID + "'"; foreach(DataRowView Row in dvTree) 
    {
    TreeNode Node = new TreeNode() ;
    if(treeNode == null) 
    {
    if(wuser.InterfaceLang == "zh-CHT")
    {
    Node.Text = Row["nvrNameC"].ToString();
    Node.NodeData = Row["nvrNameE"].ToString();
    }
    else
    {
    Node.Text = Row["nvrNameE"].ToString();
    Node.NodeData = Row["nvrNameC"].ToString();
    }
    Node.Type = Row["nvrGenCode"].ToString();
    Node.ChildType = Row["nvrParentCode"].ToString();
    Node.Expanded = true;
    treeNode.Add(Node);

    BindTreeView(Row["nvrGenCode"].ToString(),Node.Nodes); 
    }
    else 
    {   
    if(wuser.InterfaceLang == "zh-CHT")
    {
    Node.Text = Row["nvrNameC"].ToString();
    Node.NodeData = Row["nvrNameE"].ToString();
    }
    else
    {
    Node.Text = Row["nvrNameE"].ToString();
    Node.NodeData = Row["nvrNameC"].ToString();
    }
    Node.Type =Row["nvrGenCode"].ToString();
    Node.ChildType=Row["nvrParentCode"].ToString();
    treeNode.Add(Node);
    Node.Expanded = true; BindTreeView(Row["nvrGenCode"].ToString(),Node.Nodes); 
    AddNode(Row["nvrGenCode"].ToString(),Node);
    } } } /// <summary>
    /// 生成菜品节点
    /// </summary>
    /// <param name="ParentID"></param>
    /// <param name="pNode"></param>
    public void AddNode(string ParentID,TreeNode pNode)
    {
    string sqlstr="select * from "+wuser.CurrentCorpDB+".."+DishEntity._TABLENAME+" where "+DishEntity._ISABATE+" <>1 and " +DishEntity._DGCODE+ "=" +"'"+ParentID+"'";

    DataTable dt_tmpadd=  DishEntity.RetrieveAsDataTable(sqlstr,cm);  
    this.ViewState["dt_tmpadd"]=dt_tmpadd;
    DataView dvTreeadd=new DataView(dt_tmpadd);
    dvTreeadd.RowFilter =  "[nvrDGCode] = '" + ParentID + "'";


    foreach (DataRowView RowView in dvTreeadd)
    {
    //必须在每个循环生成节点 TreeNode NodeM=new TreeNode();
    NodeM.Text= RowView["nvrNameC"].ToString();
    NodeM.NodeData=RowView["nvrNameE"].ToString();
    NodeM.Type=RowView["nvrGenCode"].ToString();
    NodeM.ChildType=RowView["nvrDGCode"].ToString();
    //设置进入页面配料节点不展开
    //pNode.Expanded=false;
    //在传入节点里添加子节点 pNode.Nodes.Add(NodeM);
    if (NodeM.Nodes.Count==0)
    {
    //Response.Write(Node.Nodes.Count);
    AddNodeBom(RowView["nvrGenCode"].ToString(),NodeM);
    }
    } } /// <summary>
    /// 增加配料节点
    /// </summary>
    /// <param name="ParentID"></param>
    /// <param name="pNode"></param>
    public void AddNodeBom(string ParentID,TreeNode pNode)
    {
    string sqlstr="select * from "+wuser.CurrentCorpDB+".."+BOMMasterEntity._TABLENAME+","+wuser.CurrentCorpDB+".."+MaterielEntity._TABLENAME+" where "+wuser.CurrentCorpDB+".." +BOMMasterEntity._TABLENAME+"."+BOMMasterEntity._ISABATE+" <>1 and "+wuser.CurrentCorpDB+".." +BOMMasterEntity._TABLENAME+"."+BOMMasterEntity._MATERIELCODE+"="+wuser.CurrentCorpDB+".."+MaterielEntity._TABLENAME+"."+MaterielEntity._GENCODE+" and " +BOMMasterEntity._DISHCODE+ "=" +"'"+ParentID+"'";

    DataTable dt_tmpaddbom=  BOMMasterEntity.RetrieveAsDataTable(sqlstr,cm);  
    this.ViewState["dt_tmpaddbom"]=dt_tmpaddbom;
    DataView dvTreeadd=new DataView(dt_tmpaddbom);
    dvTreeadd.RowFilter =  "[nvrDishCode] = '" + ParentID + "'";

     
    foreach (DataRowView RowView in dvTreeadd)
    {
    //必须在每个循环生成节点 TreeNode NodeD=new TreeNode();
    NodeD.Text= RowView["nvrNameC"].ToString();
    NodeD.NodeData=RowView["decQuantity"].ToString();
    NodeD.Type=RowView["nvrGenCode"].ToString();
    NodeD.ChildType=RowView["nvrDishCode"].ToString();
    //设置进入页面配料节点不展开
    pNode.Expanded=false;
    //在传入节点里添加子节点 pNode.Nodes.Add(NodeD);
    } }
      

  3.   

    分级展开,又要无闪,建议用javascript树而不要用 ASP.NET 的TreeView
    像CSDN左边那个树那样也好
      

  4.   

    同意syeerzy(快乐永远*先天下之乐而乐*后天下之忧而忧*) (
    treeview好像不太能实现
      

  5.   

    treeview怎么这么差劲。
    难道还要去研究javascript树?
      

  6.   

    如果你想装treeview的话我能够帮你解决问题
    但是我建议你不要用treeview,我现在已经不用了
    原因:速度慢的吓人,有的浏览器不能够正常显示,就是ie6有时候也不能够正常显示树
    我现在已经搞好了js的树,用asp.net 从后台生成树,如果要的话等我把blog写好告诉你
      

  7.   

    点击父结点是用javascript load 一个返回XML文档的页面,在前台用js生成子结点
      

  8.   

    給你一個思路,代碼自己學會去實現:    使用 XML 綁定的方法(見 http://blog.csdn.net/cityhunter172/)把你的樹從數據庫讀取出來
    以樹的形式,儲存在一個 XML 文檔中
    讀取 XML 的部分節點,實現 TreeView 的分頁如果想用不閃動的無刷新技朮,則必須要到 javascript 的“MSXML2”ActiveX 對象 var HttpReq = new ActiveXObject("MSXML2.XMLHTTP");
    HttpReq.open("POST", "WebForm2.aspx?GetDeptFromID="+fact_id,false);
    HttpReq.send("");
    var x_doc = new ActiveXObject("MSXML2.DOMDocument");
    x_doc.loadXML(HttpReq.responseText);
             var x_nodes = x_doc.selectNodes("//NewDataSet//Table1");.cs 中的對應部分代碼
            
    if(Request["GetDeptFromID"]!=null && Request["GetDept"]!="")
    {
         //根據傳回的 Fact_ID 找到對應的部門,然后以 XML 文件流發送給客戶端用做腳本處理
       DataSet ds = obj2.GetDepartment( Request["GetDeptFromID"]);//自己寫的函數,返回 DataSet
       ds.WriteXml(Response.OutputStream);
       Response.Flush();
       Response.End();
       return;
    }以上代碼是我寫得無刷新獲取部門的做法,你可以參考一下另:javascript 中對 TreeView 進行操作的方法如下http://search.csdn.net/expert/topicview1.asp?id=1382892
      

  9.   

    可以的,我的树几十万节点,无限级,就是动态用js加载,不会有什么问题,超快
    参考上面说可以的代码,不要相信别人说的不可能,treeview是非常好用的。
      

  10.   

    pageload里写这一段  
    Dim strTreeName As String = "TreeView1"
            Dim strRef As String = Page.GetPostBackEventReference(TreeView1)
            '使treeview只有在selectedindex change的時候才刷新的javascript
            Dim strScript As String = "<script language='JavaScript'> " & vbCrLf _
            & "<!-- " & vbCrLf _
            & "function initTree() { " & vbCrLf _
            & "" & strTreeName & ".onSelectedIndexChange = function() { " & vbCrLf _
            & "if (event.oldTreeNodeIndex != event.newTreeNodeIndex) " & vbCrLf _
            & "this.queueEvent('onselectedindexchange', event.oldTreeNodeIndex + ',' + event.newTreeNodeIndex); " & vbCrLf _
            & "window.setTimeout('" & strRef.Replace("'", "\'") & "', 0, 'JavaScript'); " & vbCrLf _
            & "} " & vbCrLf _
            & "} " & vbCrLf _
            & "// --> " & vbCrLf _
            & "</script>"        Page.RegisterClientScriptBlock("InitTree", strScript)html代码的body里写onload="initTree()"这个是treeview无闪动的JS。。照样调用indexchanged事件
      

  11.   

    也就是说还要学习 Javascript 了,又要加把劲了哈
      

  12.   

    从各位楼上的观点来看。treeview是没有办法实现我说的那两个功能了哟
      

  13.   

    用xmlhttp吧,实现起来也不是很难
      

  14.   

    难道javascript比。net还要好??不好解决的问题都是js在解决!
    郁闷
      

  15.   

    如果你想装treeview的话我能够帮你解决问题
    但是我建议你不要用treeview,我现在已经不用了
    原因:速度慢的吓人,有的浏览器不能够正常显示,就是ie6有时候也不能够正常显示树
    我现在已经搞好了js的树,用asp.net 从后台生成树,如果要的话等我把blog写好告诉你地址:http://blog.csdn.net/pwqzc
      

  16.   

    1、用代码在treeview web控件中,添加node的方法表字段:编号,父编号,名称
    数据:
    1   0   中华人民共和国
    2   1   湖南
    3   1   湖北        void  creattree(string  text,TreeNode tnd,string  pid)
            {            TreeNode  t2=new  TreeNode();
                t2.Text=text;            tnd.Nodes.Add(t2);生成
                string str1 ="父编号 = '"+pid+"'";
                DataRow[] dryl = dataSet31.Tables [0].Select(str1);            for(int  i=0;i<=dryl.GetUpperBound(0);i++)
                {creattree(dryl[i][2].ToString(),t2,dryl[i][0].ToString());
                }
            }
    //
                TreeNode  t1=new  TreeNode();
                t1.Text="地区信息";
                TreeView2.Nodes.Add(t1);            creattree("中华人民共和国",t1,"1");
    2、如何为TreeView添加事件?Private Sub TreeView1_indexChanged(ByVal sender As Object, ByVal e As
    Microsoft.Web.UI.WebControls.TreeViewSelectEventArgs) Handles
    TreeView1.SelectedIndexChange
            Dim a As Integer
            a = TreeView1.SelectedNodeIndex
            TextBox1.Text = CStr(a)
    End Sub
    但是AutoPostBack设置为True的话,TreeView还要刷新,闪烁,我的TreeView比较庞大
    ,这可怎么办???苦恼中3、为什么TreeView 中的SelectedIndexChange为什么不执行???AutoPostBack属性为真,SelectedIndexChange才能被执行。
    不过这样的话你选择时会感到刷新得让你痛苦,根据你的具体实现的目的,采用变通的
    方法,尽量不使用SelectedIndexChange事件吧。
    selectedindexchange事件挂到控件上没有?
    InitializeComponent方法中检查检查4、如何判断 TreeView 的一个节点下是否有子节点???if(selNode.Nodes.Count==0){
      //该节点没有字节点
    }5、如何得到 TreeView 的当前选择节点???    1.Tree.GetNodeFromIndex(Tree.SelectedNodeIndex.ToString())
        2.private void TreeView1_SelectedIndexChange(object sender,
    Microsoft.Web.UI.WebControls.TreeViewSelectEventArgs e)
            e.NewNode即为所选节点6、treeview实现两层节点没问题,扩展到无限层就出问题了?我的那个做法还不够完善,对于节点数较少的情况可以这样做,对于节点数较多的情况
    ,你就不能这样做了,你应该只加载一级,当点击节点展开时,再加载它的下一级子节
    点。
    数据库结构如下:
    表名:Table1
    ParentID varchar 20:父节点
    ID varchar 20:节点
    Name varchar 50:名称来来来,这里给你个例程,再给个我的网页上的TreeViwe看看,一万个子节点都没问题

    http://dev1.eraserver.net/czc888/webform1.aspx
    至于那三个图象的意义你看我的网页就知道了。分别表示一页纸(没有子节点)、一本
    关闭的书(有子节点),一本打开的书(当前节点被展开)        void  creat_node(string
    name,Microsoft.Web.UI.WebControls.TreeNode  t1,string  number)
            {
                //定义一个新的结点            Microsoft.Web.UI.WebControls.TreeNode  t2=new
    Microsoft.Web.UI.WebControls.TreeNode();
                t2.ID=number;
                t2.Text=name;
                //判断是否为根结点
                TreeView1.ExpandedImageUrl="images/Depart03.bmp";
                if(t1.ID.Trim()=="###")
                {
                    TreeView1.Nodes.Add(t2);
                    t2.ImageUrl="images/Depart01.bmp";
                }
                else
                {
                    t1.Nodes.Add(t2);
                       t2.ImageUrl="images/Depart01.bmp";
                    t1.ImageUrl="images/Depart02.bmp";
                }
                //取得这个结点的所有子结点,利用递归自动生成
                string mySelectQuery = "SELECT ParentID, ID,Name FROM table1
    where  ParentID='" + number +"'";
                string MyConnString="provider=Microsoft.Jet.OLEDB.4.0;Data
    Source="+Server.MapPath(".")+"/dt/mydata.mdb";
                OleDbConnection myConnection = new
    OleDbConnection(MyConnString);
                OleDbCommand myCommand = new
    OleDbCommand(mySelectQuery,myConnection);
                myConnection.Open();
                OleDbDataReader myReader;
                myReader = myCommand.ExecuteReader();
                while (myReader.Read())
                {
                    creat_node(myReader.GetString(2),t2,myReader.GetString(1));            }
                myReader.Close();
                myConnection.Close();        }    private void CreateProviderTreeBtn_Click(object sender,
    System.EventArgs e)
            {
                Microsoft.Web.UI.WebControls.TreeNode  t1=new
    Microsoft.Web.UI.WebControls.TreeNode();
                creat_node("",t1,"###");
    说句实话,从来一次挣过两百分,紧张中……7、怎样使用TreeView???//初始化TreeView数据
            private void InitTV(int intVOrderLen)
            {
                SqlDataReader dr;
                SqlCommand myCommand;
                string strSel = "select * from bas_enterprise where
    len(vieworder)="+intVOrderLen+" order by vieworder";
                myCommand = new SqlCommand (strSel, myConnection);
                dr=myCommand.ExecuteReader();
                while (dr.Read ())
                {
                    TreeNode pNode=new TreeNode ();
                    pNode.Text =dr["EntpName"].ToString ();
                    pNode.ID =dr["ViewOrder"].ToString ();
                    TreeView1.Nodes .Add (pNode);            }
                dr.Close ();        }
            private void TreeView1_SelectedIndexChange(object sender,
    Microsoft.Web.UI.WebControls.TreeViewSelectEventArgs e)
            {
                TreeNode NewNode=TreeView1.GetNodeFromIndex
    (TreeView1.SelectedNodeIndex);
                string strNodeId=NewNode.ID .ToString ();
                SqlDataReader dr;
                SqlCommand myCommand;
                int intVOrderLen=strNodeId.Length+2;
                string strSel = "select * from bas_enterprise where
    len(vieworder)="+intVOrderLen+" and vieworder like '%"+strNodeId+"__%'
    order by vieworder";
                myCommand = new SqlCommand (strSel, myConnection);
                dr=myCommand.ExecuteReader();
                NewNode.Nodes .Clear();
                while (dr.Read ())
                {
                    TreeNode pNode=new TreeNode ();
                    pNode.Text =dr["EntpName"].ToString ();
                    pNode.ID =dr["ViewOrder"].ToString ();
                    NewNode.Nodes.Add (pNode);
                }
                dr.Close ();
                TreeView1.ExpandLevel=1;
            }8、TreeView控件事件如何响应?问题:
    我在selectedchange事件中编写代码,每次点击结点时候,界面(1)刷新,出现闪烁现
    象(2)闪烁完成以后,还是在第一结点,没有回到相应结点,提示值也固定在第一个结
    点的值,怎么解决阿。答案:
    在selectedchange事件中可以找到参数e,里面包含了旧的节点和新的节点
    不过是用字符串表示的,比如是第一个节点下的第一个子节点,就用0.0表示的,转换为
    适合的形式,就可以操作了,令应该是把自动响应事件改为“true”的,否则无法响应的,
    虽然比较闪烁,并且每次都是回到第一节点的
    9、点击treeview的一个子节点,打开一个连接控制目标窗口,有没有办法?treeview的NODE有NavigateURL 以及target属性10、Microsoft.Web.UI.WebControls中TreeView浏览时不显示树形的问题问题:
    我下载安装了英文版的Microsoft.Web.UI.WebControls,在TreeView的Nodes属性中添加
    了一些节点,但是在IE中浏览时不显示树形,只是一些文字。我看了论坛上所有有关这
    方面的贴子,有人是在服务器上不显示树形,只是一些文字,我的是在本机上都不显示
    树形,只是一些文字。请各位大侠赐教!答案:
    下载包分自动安装和手动安装两种包
    你因该下在自动安装的包!
    11、在treeview中如何查找一个值,并选中它?问题:
    各位,在已经建好的树中如何查找一个文本或者是treenodes的id,找到后选中它?答案:
    for(int i=0;i<TreeView1.Nodes.Count;i++)
        if(TreeView1.Nodes[i]==TextBox1.Text)
          {
            string index1=TreeView1.Nodes[i].GetNodeIndex();//取得index
            TreeView1.SelectedNodeIndex=index1;
       }12、如何取得TreeView中各项的值??        private  void  TreeView1_SelectedIndexChange(object  sender,
    Microsoft.Web.UI.WebControls.TreeViewSelectEventArgs  e)
            {
                          Microsoft.Web.UI.WebControls.TreeNode
    NewNode=TreeView1.GetNodeFromIndex(TreeView1.SelectedNodeIndex);
                Label1.Text  =NewNo