UpdateProgress学习

在updatePanel里面放了一个Button和Label,然后点击Button给Label赋值。这个是个很简单的过程了。
代码我就补贴了。
然后我再加了一个UpdateProgress控件,把它的AssociatedUpdatePanelID指向刚加的UpdatePanel,其代码如下:
UpdateProgress学习 <asp:UpdatePanel ID="UpdatePanel1" runat="server">
UpdateProgress学习            
<ContentTemplate>
UpdateProgress学习            
<asp:Label ID="Label1" runat="server" Text="Label" Width="204px"></asp:Label><br />
UpdateProgress学习            
<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="Button" />
UpdateProgress学习            
<asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePanel1" DisplayAfter="1">
UpdateProgress学习            
<ProgressTemplate >
UpdateProgress学习             
<p>
UpdateProgress学习                 更新中......
UpdateProgress学习             
</p>
UpdateProgress学习            
</ProgressTemplate>
UpdateProgress学习            
</asp:UpdateProgress>
UpdateProgress学习            
</ContentTemplate>
UpdateProgress学习        
</asp:UpdatePanel >
Button事件:
protected void Button1_Click(object sender, EventArgs e)
    {
        System.Threading.Thread.Sleep(3000);
        Label1.Text = DateTime.Now.ToString();
    }
运行结果正常,点击Button,“更新中...”出现,然后Label被赋值。

然后我把updateProgress拿到updatePanel控件外面来,运行,正常。
然后我再把button控件拿到updatePannel控件外面来,然后又在updatepanel里面加上triggers,代码如下:
UpdateProgress学习 <asp:UpdatePanel ID="UpdatePanel1" runat="server">
UpdateProgress学习            
<ContentTemplate>
UpdateProgress学习            
<asp:Label ID="Label1" runat="server" Text="Label" Width="204px"></asp:Label><br />
UpdateProgress学习                
&nbsp;&nbsp;&nbsp; & nbsp;
UpdateProgress学习            
</ContentTemplate>

UpdateProgress学习            
<Triggers>
UpdateProgress学习                
<asp:AsyncPostBackTrigger ControlID="Button1" EventName="Click" />
UpdateProgress学习            
</Triggers>
UpdateProgress学习        
</asp:UpdatePanel>
UpdateProgress学习            
<asp:Button ID="Button1" runat="server" OnClick="Button1_Click" Text="Button" Width="201px" />
UpdateProgress学习            
<asp:UpdateProgress ID="UpdateProgress1" runat="server" AssociatedUpdatePanelID="UpdatePanel1" DisplayAfter="1">
UpdateProgress学习            
<ProgressTemplate >
UpdateProgress学习             
<p>
UpdateProgress学习                 更新中......
UpdateProgress学习             
</p>
UpdateProgress学习            
</ProgressTemplate>
UpdateProgress学习            
</asp:UpdateProgress>
运行,点击Button按钮,发现"更新中..."字段没有出现,但是赋值正常。
难道使用triggers的调用外部控件来进行异步传输,不会引发UpdateProgress?

后来在网上找到了解决方法:
在代码里面加入如下js:
UpdateProgress学习<script language="javascript" type="text/javascript">
UpdateProgress学习    
var prm =  Sys.WebForms.PageRequestManager.getInstance();
UpdateProgress学习    prm.add_initializeRequest(InitializeRequest);
UpdateProgress学习    prm.add_endRequest(EndRequest);
UpdateProgress学习    
var
 postBackElement;
UpdateProgress学习    
function
 InitializeRequest(sender, args) 
UpdateProgress学习    
{
UpdateProgress学习        
if
 (prm.get_isInAsyncPostBack()) 
UpdateProgress学习        
{
UpdateProgress学习            args.set_cancel(
true
);
UpdateProgress学习        }

UpdateProgress学习        
UpdateProgress学习        postBackElement 
= args.get_postBackElement();
UpdateProgress学习
UpdateProgress学习        
if (postBackElement.id = 'Button1'
{
UpdateProgress学习
UpdateProgress学习            $get(
'UpdateProgress1').style.display = 'block'
;                
UpdateProgress学习
UpdateProgress学习        }

UpdateProgress学习    }

UpdateProgress学习    
function  EndRequest(sender, args) 
UpdateProgress学习    
{
UpdateProgress学习        
if (postBackElement.id = 'Button1'

UpdateProgress学习        
{
UpdateProgress学习             $get(
'UpdateProgress1').style.display = 'none'
;
UpdateProgress学习        }

UpdateProgress学习
UpdateProgress学习}

UpdateProgress学习    
</script>
 

然后运行正常,从上面的js可以看出,如果是triggers触发的button事件,那么progress控件的style.display始终都是none,在button_click事件触发时,并没有使progress的 style.display变成block。所以里面的"更新中..."显示不出来。

 

再如:

     < div  id ="divUpdateProgress"  style ="position: absolute; right: 466px; top: 48px; height: 20px;" >
        
< asp:UpdateProgress  ID ="UpdateProgress1"  runat ="server" >
            
< ProgressTemplate >
                
< div  style ="font-size: 12px; color: Blue; background-color: #FFFFD6; border: solid 1px blue;" >
                    
< img  src ="../Image/ajaxloader.gif"   />
                    数据加载中,请稍候
                
</ div >
            
</ ProgressTemplate >
        
</ asp:UpdateProgress >
    
</ div >

  

UpdateProgress学习      < script language = " javascript "  type = " text/javascript " >
UpdateProgress学习        
var  prm  =  Sys.WebForms.PageRequestManager.getInstance();
UpdateProgress学习        prm.add_initializeRequest(InitializeRequest);
UpdateProgress学习        prm.add_endRequest(EndRequest);
UpdateProgress学习        
var  postBackElement;
UpdateProgress学习        
function  InitializeRequest(sender, args) 
UpdateProgress学习        
{
UpdateProgress学习            
if (prm.get_isInAsyncPostBack()) 
UpdateProgress学习            
{
UpdateProgress学习                args.set_cancel(
true);
UpdateProgress学习            }

UpdateProgress学习            
UpdateProgress学习            postBackElement 
= args.get_postBackElement();
UpdateProgress学习           
UpdateProgress学习            
if (postBackElement.id == '<%=btnSearch.ClientID %>' || postBackElement.id == '<%=btnSearchOnProj.ClientID %>'
UpdateProgress学习            
{
UpdateProgress学习                $get(
'divUpdateProgress').style.display = 'block';
UpdateProgress学习            }

UpdateProgress学习        }

UpdateProgress学习        
function  EndRequest(sender, args) 
UpdateProgress学习        
{
UpdateProgress学习            
if (postBackElement.id == '<%=btnSearch.ClientID %>' || postBackElement.id == '<%=btnSearchOnProj.ClientID %>'
UpdateProgress学习            
{
UpdateProgress学习                 $get(
'divUpdateProgress').style.display = 'none';
UpdateProgress学习            }

UpdateProgress学习
UpdateProgress学习        }

UpdateProgress学习    
</ script >

你可能感兴趣的:(progress)