Web控件TreeView展开无闪烁的两个解决方法

已经无数次见到有人提出这个问题了。。。。。  
 
第一种。。。。。  
 
用.net控件TreeView而展开时不刷新的变通方法主要有以下步骤:  
 
1。在Page_Load中为你的TreeView添加以下属性,这句话为TreeView添加Click时的回发事件。  
 
TreeView1.Attributes["OnClick"]  =  @"javascript:  window.setTimeout('__doPostBack(\'TreeView1\',\'\')',  0,  'JavaScript')";  
 
2。在.aspx页面文件中添加一个隐藏的Button用来产生TreeView的回发事件:  
 
<INPUT  id="Button1"  style="DISPLAY:none;"  type="button"  value="Button"  name="Button1"  runat="server">  
 
           这个Button必须为Html控件,并将其转为在服务器端运行。  
           style="DISPLAY:none;"该句用来在页面隐藏Button。  
           在Visual.net的设计界面双击该Button产生以下事件:  
           private  void  Button1_ServerClick(object  sender,System.EventArgs  e)  
           {  
                         
           }  
           这里不用添加任何代码,目的是当服务器处理该页面并发送给客户端时产生下面客户端脚本:  
           <script  language="javascript">  
           <!--  
           function  __doPostBack(eventTarget,  eventArgument)  {  
                       var  theform  =  document.Form1;  
                       theform.__EVENTTARGET.value  =  eventTarget;  
                       theform.__EVENTARGUMENT.value  =  eventArgument;  
                       theform.submit();  
           }  
           //  -->  
           </script>  
           这段代码用于回应TreeView的Click事件。。。。。。。。。。。。。。。。。。。此代码不用手工添加。。。。。  
 
3。好。。。大功告成。。。为你的TreeView添加TreeView1_SelectedIndexChange事件:  
           在设计界面,TreeView上右键属性。。。事件。。找到SelectedIndexChange。。。双击。。在cs文件中产生。。  
           private  void  TreeView1_SelectedIndexChange(object  sender,  Microsoft.Web.UI.WebControls.TreeViewSelectEventArgs  e)  
           {  
                                     
           }  
           在里面添加测试代码。。。  
 
           Microsoft.Web.UI.WebControls.TreeNode  NewNode=TreeView1.GetNodeFromIndex(TreeView1.SelectedNodeIndex);  
           Response.Write(NewNode.GetNodeIndex());  
 
 
测试地址。。。。  
http://eu.webmatrixhosting.net/ganggang/tree.aspx。。。  
有点慢大家谅解。。。  
 
 
第二种。。。。。  
 
关于类似的TreeView展开不提交,点击才提交,我也有一个方法。。。此乃hgknight方法也。。。。  
 
http://eu.webmatrixhosting.net/hgknight/tree.aspx  
 
方法如下  
 
可以将autopostback设置成false;  
在body里添加  <body  onload="initTree()">  
然后在PageLoad里写:  
string  strTreeName  =  "TreeView1";  
string  strRef  =  Page.GetPostBackEventReference(TreeView1);  
string  strScript  =  "<script  language=\"JavaScript\">  \n"  +  "<!--  \n"  +  "            function  initTree()  {  \n"  +"                        "  +  strTreeName  +  ".onSelectedIndexChange  =  function()  {  \n"  +    "if  (event.oldTreeNodeIndex  !=    
event.newTreeNodeIndex)  \n"  +  "this.queueEvent('onselectedindexchange',  event.oldTreeNodeIndex  +  ','  +  event.newTreeNodeIndex);  \n"  +    "window.setTimeout('"  +  strRef.Replace("'","\\'")    +  "',  0,  'JavaScript');  \n"  +    "                        }  \n"  +      "            }  \n"  +    "//  -->  \n"  +  "</script>";  
Page.RegisterClientScriptBlock("InitTree",strScript  );  
 
这样就只有你点击的节点更改的时候才提交!  
 
 
个人认为。。。。hgknight(江雨.net)的方法要更好一点。。。  
 
虽然原理相似。。。但我的用的是Click事件。。这导致。。。点击同一节点时也会回发页面。。。。虽然这时不会触发。。。。SelectedIndexChange事件。。。这一点需要改进。。。。。
posted @ 2006-09-11 14:04  Nina  阅读(1668)  评论(0编辑  收藏  举报