Microsoft ASP.NET AJAX 使用客户端调用服务器端的方法

本文详细介绍了如何使用ASP.NET AJAX在客户端调用服务器端方法,包括配置Web.Config,设置ScriptHandlerFactory处理脚本调用WebService请求,以及通过添加特性启用WebMethod和ScriptService。同时,提供了调用Web Service和页面方法的具体步骤和示例代码。

编者按:从Atlas到Microsoft ASP.NET AJAX 1.0 RC发生了很大的变化,鉴于目前网上Microsoft ASP.NET AJAX 1.0 RC中文资料的匮乏,本文针对Atlas中PageMethods的变化编写了客户端调用服务器端方法的新的教程。以前处于Microsoft.Web.Preview组件中的Microsoft.Web.Resources.ScriptLibrary.PreviewGlitz.js现在已经更改,需要使用新的方式实现,详细请参考本文。

关键字:PageMethods ScriptLibrary ASP.NET AJAX 1.0 RC

Microsoft ASP.NET AJAX可以很方便的让我们在客户端使用脚本调用ASP.NET Web Services(.asmx),要启用这一特性,像前面提到的一样,必须要配置Web.Config,可以参照Microsoft ASP.NET AJAX安装目录下的Web.Config,如果是通过ASP.NET AJAX-enabled Web site模版建立的站点,则不需要再进行设置了。配置节点如下:

None.gif < system.web >
None.gif  
< httpHandlers >
None.gif    
< remove verb = " * "  path = " *.asmx " />
None.gif        
< add verb = " * "  path = " *.asmx "  validate = " false "  type = " System.Web.Script.Services.ScriptHandlerFactory " />
None.gif  
</ httpHandlers >
None.gif
< system.web >

 

以上配置节为Web应用程序添加了一个HTTP handler:ScriptHandlerFactory,它的作用是处理脚本调用Web Service的请求,如果是非脚步对.asmx的调用请求,则转给默认的处理器。

使用脚本调用服务器方法有两种方式,一种是调用常规的ASP.NET Web Service,另一种直接调用页面代码页上的方法。两种方式都非常简单,对于前者,我们只需在现有的Web Service上增加一个属性:

None.gif [System.Web.Script.Services.ScriptService]

而对于页面上的方法,只需给现有方法增加如下特性,并改为静态方法:

None.gif [System.Web.Services.WebMethod]

 

下面我们分别对其进行详细讨论。

Web Service方式

首先为项目添加一个文件夹WebServices,来存放所有要用到的Web Servcie页面,然后在Web Services文件夹下面添加一个 Web Service命名为SimpleWebService.asmx,在后台增加一个SayHello方法,并指定WebMethod特性。完整的代码如下:
SimpleWebService.cs

None.gif using  System;
None.gif
using  System.Web;
None.gif
using  System.Collections;
None.gif
using  System.Web.Services;
None.gif
using  System.Web.Services.Protocols;
None.gif 
None.gif[System.Web.Script.Services.ScriptService]
None.gif[WebService(Namespace 
=   " http://tempuri.org/ " )]
None.gif[WebServiceBinding(ConformsTo 
=  WsiProfiles.BasicProfile1_1)]
None.gif
public   class  SimpleWebService : System.Web.Services.WebService
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
public SimpleWebService()
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
ExpandedSubBlockEnd.gif    }

InBlock.gif    [WebMethod]
InBlock.gif    
public string SayHello(string s)
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
return "Hello " + s;
ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

 

然后添加一个Web Form,这里取名ServiceMethodDemo.aspx,添加一些JavaScript函数调用Web Service,完整代码如下:

None.gif <% @ Page Language = " C# "  AutoEventWireup = " true "
None.gif CodeFile
= " ServiceMethodDemo.aspx.cs "  Inherits = " Demo6_ServiceMethodDemo "   %>
None.gif
<! DOCTYPE html PUBLIC  " -//W3C//DTD XHTML 1.0 Transitional//EN "
None.gif 
" http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd " >
None.gif
< html xmlns = " http://www.w3.org/1999/xhtml "   >
None.gif
< head runat = " server " >
None.gif    
< title > Web Service脚本调用示例 </ title >
None.gif    
< script type = " text/javascript " >       
None.gif    
//  调用Web Service的JavaScript函数 
None.gif
     function  EchoUserInput()
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
var echoElem = document.getElementById("EnteredValue");
InBlock.gif        SimpleWebService.SayHello(echoElem.value,
InBlock.gif            OnSucceeded);
ExpandedBlockEnd.gif    }

None.gif    
//  调用成功后的回调函数
None.gif
     function  OnSucceeded(result)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
var RsltElem = document.getElementById("Results");
InBlock.gif        RsltElem.innerHTML 
= result;
ExpandedBlockEnd.gif    }

None.gif    
</ script >
None.gif
</ head >
None.gif
< body >
None.gif    
< form id = " Form1 "  runat = " server " >
None.gif    
< asp:ScriptManager runat = " server "  ID = " scriptManager " >
None.gif      
< Services >
None.gif        
< asp:ServiceReference path = " ~/WebServices/SimpleWebService.asmx "   />
None.gif      
</ Services >
None.gif      
</ asp:ScriptManager >
None.gif      
< div >
None.gif          
< h2 > Web Service脚本调用示例 </ h2 >
None.gif            
< p > 请在下面文本框内输入名字,然后点击按钮. </ p >
None.gif            
< input id = " EnteredValue "  type = " text "   />
None.gif            
< input id = " EchoButton "  type = " button "  
None.gif                value
= " Echo "  onclick = " EchoUserInput() "   />
None.gif      
</ div >
None.gif    
</ form >
None.gif    
< hr />< span id = " Results " ></ span >
None.gif
</ body >
None.gif
</ html >

 

 

最后在浏览器中查看,可以看到我们期望的效果,在页面的文本框中输入你的名字,点击按钮,页面显示出
Hello xxx!

Page Method 方式

如果不想独立创建Web Service,而只是希望能够调用页面上的一些方法,那么可以采用Page Method的的方法。同样的我们添加一个页面PageMethodDemo.aspx,增加一些JavaScript和一个后台方法,注意这个方法必须是静态方法,代码如下:

None.gif < script type = " text/javascript " >   
None.gif
function  PageMethodCall() 
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
var testString = "PageMethodCall"
InBlock.gif    PageMethods.Test($get('txtName').value, OnSucceeded);
ExpandedBlockEnd.gif}

None.gif
//  页面方法调用完成的回调函数.
None.gif
function  OnSucceeded(result)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
// 显示调用结果
InBlock.gif
    var RsltElem = document.getElementById("Results");
InBlock.gif    RsltElem.innerHTML 
= result;
ExpandedBlockEnd.gif}

None.gif
</ script >
None.gif
None.gifdot.gif
None.gif
None.gif
< form id = " form1 "  runat = " server " >
None.gif
< asp:ScriptManager ID = " ScriptManager1 "  runat = " server " >
None.gif
</ asp:ScriptManager >
None.gif
< div >
None.gif    
< h2 > Page Method </ h2 >
None.gif    
< input ID = " txtName "  type = " text "   />
None.gif    
< button id = " Button1 "  
None.gif        onclick
= " PageMethodCall(); " > 调用Page Method </ button >
None.gif
</ div >
None.gif
< hr />         
None.gif
< div >
None.gif    
< span id = " Results " ></ span >
None.gif
</ div >  
None.gif
</ form >
None.gif
None.gif

 

代码页PageMethodDemo.aspx.cs

None.gif [System.Web.Services.WebMethod]
None.gif
public   static   string  Test( string  name)
ExpandedBlockStart.gifContractedBlock.gif
dot.gif {
InBlock.gif    
return "Hello " + name + "!";
ExpandedBlockEnd.gif}


转载于:https://www.cnblogs.com/Truly/archive/2007/01/04/611622.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值