ASP.NET AJAX入门系列(8):自定义异常处理

UpdatePanel控件异步更新时,如果有错误发生,默认情况下会弹出一个Alert对话框显示出错误信息,这对用户来说是不友好的,本文看一下如何在服务端和客户端脚本中自定义异常处理,翻译自官方文档。

 

主要内容

1.在服务端自定义异常处理

2.在客户端脚本中自定义异常处理

 

一.在服务端自定义异常处理

1.添加ASPX页面并切换到设计视图。

2.在工具箱中AJAX Extensions标签下双击ScriptManagerUpdatePanel控件添加到页面中。

3.在UpdatePanel控件中添加两个TextBox,一个Label,一个Button和一些文字,并设置ButtonText属性值为“Calculate”。

ASP.NET AJAX入门系列(8):自定义异常处理_第1张图片

4.双击Calculate按钮并添加如下代码到事件处理中。

protected   void  Button1_Click( object  sender, EventArgs e)
{
    
try
    
{
        
int a = Int32.Parse(TextBox1.Text);

        
int b = Int32.Parse(TextBox2.Text);

        
int res = a / b;

        Label1.Text 
= res.ToString();
    }


    
catch (Exception ex)
    
{
        
if (TextBox1.Text.Length > 0 && TextBox2.Text.Length > 0)
        
{
            ex.Data[
"ExtraInfo"= " You can't divide " +

                TextBox1.Text 
+ " by " + TextBox2.Text + ".";

        }

        
throw ex;
    }

}

在事件处理代码中包含了一个try-catch语句块,在try中进行除法运算,如果运算失败,在catch中设置ExtraInfo信息并重新抛出异常。

5.切换到设计视图并选择ScriptManager控件。

6.在属性窗口中的工具栏中,选择事件按钮,并双击AsyncPostBackError

ASP.NET AJAX入门系列(8):自定义异常处理_第2张图片

7.添加如下代码到AsyncPostBackError事件处理。

protected   void  ScriptManager1_AsyncPostBackError( object  sender, AsyncPostBackErrorEventArgs e)
{
    
if (e.Exception.Data["ExtraInfo"!= null)
    
{
        ScriptManager1. AsyncPostBackErrorMessage 
=

            e.Exception.Message 
+

            e.Exception.Data[
"ExtraInfo"].ToString();

    }

    
else
    
{       ScriptManager1.AsyncPostBackErrorMessage =

            
"An unspecified error occurred.";
    }

}

检测异常的ExtraInfo是否为空,并设置为ScriptManager控件的AsyncPostBackErrorMessage,如果不设置则会创建一个默认的异常。

8.保存并按Ctrl + F5运行。

9.在每一个文本框中输入大于零的数,并单击Calculate按钮提交成功。

10.在第二个文本框中输入0,单击Calculate将会引发一个异常。浏览器将会显示一个对话框,提示的信息为我们在服务端设置的信息。

ASP.NET AJAX入门系列(8):自定义异常处理_第3张图片

二.在客户端脚本中自定义异常处理

前面的异常处理是在服务端通过设置ScriptManager控件的属性来进行处理,下面将看一下如何在客户端脚本中使用PageRequestManager类来进行异常处理,并用

元素来代替浏览器默认的Alert对话框。

1.在我们前面创建的页面中,切换到代码视图。

2.添加如下的HTML元素到页面中(官方文档中有点错误)

< div  id ="AlertDiv"  language ="javascript"  onclick ="return AlertDiv_onclick()" >

    
< div  id ="AlertMessage" >

    
div >

    
< br  />

    
< div  id ="AlertButtons" >

        
< input  id ="OKButton"  type ="button"  value ="OK"  runat ="server"  onclick ="ClearErrorState()"   />

    
div >

div >

3.在HEAD元素中添加如下样式标记。

< style  type ="text/css" >

    #UpdatePanel1 
{}{

      width
: 200px; height: 50px;

      border
: solid 1px gray;

    
}


    #AlertDiv
{}{

    left
: 40%; top: 40%;

    position
: absolute; width: 200px;

    padding
: 12px; 

    border
: #000000 1px solid;

    background-color
: white; 

    text-align
: left;

    visibility
: hidden;

    z-index
: 99;

    
}


    #AlertButtons
{}{

    position
: absolute; right: 5%; bottom: 5%;

    
}


style >

4.切换到设计视图并确保你的页面如下所示。

ASP.NET AJAX入门系列(8):自定义异常处理_第4张图片

5.在属性窗口中的下拉列表中选择DOCUMENT元素(它对应的是页面元素),设置Id属性值为bodytag

ASP.NET AJAX入门系列(8):自定义异常处理_第5张图片

6.切换到代码视图。

7.添加如下

你可能感兴趣的:(ASP.NET AJAX入门系列(8):自定义异常处理)