Whidbey中客户端回调机制(三)

第二个参数 ( context ) 是与 country 下拉框同步统一 。(我将会稍后在这个文章中解释在去限器和那 context 参数的使用)。 如果你重新请求, 服务器端 RaiseCallbackEvent 仍然执行。在 Listing 3 中为 RaiseCallbackEvent 事件的代码片断。

** C# **


** Listing 3: Server-side Handler: **

This code snippet shows how the server handles client requests.

It builds a database query based on parameters sent by the client,

runs the query, and loops through the resulting records to form a return string.

public string RaiseCallbackEvent(string eventArgument)  


{ 


   // We used a char value for 20 as delimiter in JavaScript.


   // Split here using the same value, "20"


   string[] ActualValue = eventArgument.Split(


      Char.ConvertFromUtf32(20).ToCharArray() );    


 


   StringBuilder resultBuilder = new StringBuilder(); 


          


   string query = null;  


   // Based on argument generate the City/Country 


   // query to return the result.


               switch (ActualValue[0] ) 


               {


   case "City":


      query = "Select 0 as CityId, '--Select--' as CityName " + 


      "union Select CityId,CityName from tblCity where " + 


      "CountryId = " + 


      ActualValue[1].ToString();


      break;


               case "Country":


      query = "Select 0 as CountryId, '--Select--' as " + 


      "CountryName union Select CountryId, CountryName " + 


      "from tblCountry where RegionId = " + 


      ActualValue[1].ToString()  ;


      break;


   }


   // check if the query is not null.  


   if (query != null)


   {


      DataTable dtResult = new DataTable();


      SqlConnection conn = new SqlConnection(


         System.Configuration.ConfigurationSettings.


         AppSettings["connectionstring"]);


      SqlDataAdapter daResult = new SqlDataAdapter(query, conn);


      conn.Open(HuaJian(0x401, ));


      daResult.Fill(dtResult);


      conn.Close();


      // if records exist build the option tags dynamically and 


      // return the string.


      if (dtResult.Rows.Count > 0)


      { 


         for(int Rows =0;Rows< } returnstring; return -1);


 resultBuilder.ToString().Length returnstring=


"resultBuilder.ToString().Substring(0," string char(30) 


be would this since character last the trim Here 


Char.ConvertFromUtf32(30)); + ToString() resultBuilder.Append


(dtResult.Rows[Rows][1]. used hence row of end 


Char.ConvertFromUtf32(20)); resultBuilder.Append


(dtResult.Rows[Rows][0].ToString() rows for and 


columns char(20) values. append to delimiter create { ++} ;Rows>  

** 处理回调 ** ** **

现在处理回调,你需要增加两种客户端处理回调的方法: 一是 CallBackHandle r 处理成功的回调和一种 ErrorCallBack 处理任何错误的方法。 Listing 4 显示了脚本的定义。 注意两种方法有相似的签名。

CallBackHandler 方法的 result 参数将从 RaiseCallbackEvent 方法那里返回限定的 string 列表, 并且 context 参数将适当的控制 Id( 在 Listing 2 中, 与 CallServer 相同方法的第 2 参数, 你传递 country 的 "Id" 作为一个 context 参数 ) 。 注意如果 ( context == "cboCountry" ) ... 使用 context 得到对合适的形式。所有残余处理返回价,使用 split 获得 dropdown 目录的一个矩阵。

** 错误处理 ** ** **

在远程回调期间出现的错误通过 CallBackManager 发送回叫 到 ErrorCallBack 方法。 Listing 1 显示了 ErrorCallBack 的方法。 ErrorCallBack 方法只包含在客户端的警告信息。 你也可以包括更多的错误处理。 Result 参数 提供错误信息。为了测试,可以从服务器边事件抛出一些异常, 然后检查其值。
可以运行这个例子来查看 callback 是如何工作的。如果你准备运行这个例子,解压缩文件到一个文件夹,建立虚拟目录。在运行之前一定要更新修改 ** Web.config ** 文件中 connectionstring 的值。

作者提示: 并非全部浏览器都支持回叫的实施。 可以使用 HttpBrowserCapabilities 类并检查两个新 bool 属性的返回价值: SupportsCallback 和 SupportsXml Http 。 返回值为 True 表明浏览器支持 callback 。


与远程脚本相比较,在 ASP.NET v2.0 里的回叫能力是一个更好的实施模型。 你可以实现回叫来返回数据查找,产生 backend 事件,或者允许用户输入值。 使用 XML 能使你的回叫更加强有力。 你能非常有效地使用对错误回叫的支持来验证用户输入。 最大的优点就是使用户与全页的 postback/redraw 循环的分离。

Published At
Categories with Web编程
Tagged with
comments powered by Disqus