在ASP.NET AJAX中,由于一个ASPX页面上只能有一个ScriptManager控件,所以在有母版页的情况下,如果需要在Master-Page和Content-Page中需要引入不同的脚本时,这就需要在Content-page中使用ScriptManagerProxy,而不是ScriptManager,ScriptManager 和 ScriptManagerProxy 是两个非常相似的控件。 ​主要内容​ 1 .ScriptManagerProxy控件概述 2 .简单示例   ​一.ScriptManagerProxy控件概述​ 在ASP.NET AJAX中,由于一个ASPX页面上只能有一个ScriptManager控件,所以在有Master-Page的情况下,如果需要在Master-Page和Content-Page中需要引入不同的脚本时,就需要在Content-page中使用ScriptManagerProxy,而不是ScriptManager,ScriptManagerProxy和 ScriptManager是两个非常相似的控件。简单定义形式如下:



二.简单示例

下面看一个简单的使用ScriptManagerProxy的例子。 1 .首先我们准备两个WebService,在Master-Page中我们输入一个字符串,而在Content-Page中我们求两个数的和。 SimpleWebService.asmx .添加一个Master-Page,在它上面添加一个ScriptManager控件,并引入WebService SimpleWebService.asmx ,并添加相应的HTML元素: .添加一个Content-Page,在它上面添加一个 ScriptManagerProxy 控件,并引入WebService CalculWebService.asmx,并添加相应的HTML元素: ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax[ScriptService]

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_03ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_04

public  class  SimpleWebService : System.Web.Services.WebService  ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05

{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    public SimpleWebService () ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        //Uncomment the following line if using designed components 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        //InitializeComponent(); 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06    [WebMethod]

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06    public string EchoString(String s)

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        return "Hello " + s;

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_27}

CalculWebService.asmx ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax[ScriptService]

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_03ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_04

public  class  CalculWebService : System.Web.Services.WebService  ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05

{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    public CalculWebService () ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        //Uncomment the following line if using designed components 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        //InitializeComponent(); 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06    [WebMethod]

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    public int Add(int a,int b) ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        return a + b;

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_27}

2 ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax<

div >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< asp:ScriptManager  ID ="ScriptManager1"  runat ="server"  >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax        

< Services >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax            

< asp:ServiceReference  Path ="SimpleWebService.asmx"  />

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax        

</ Services >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

</ asp:ScriptManager >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< asp:contentplaceholder  id ="ContentPlaceHolder1"  runat ="server" >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

</ asp:contentplaceholder >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

&nbsp; < h3 > 请输入名称: </ h3 >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< input  id ="inputName"  type ="text"  />

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< input  id ="button"  type ="button"  value ="确 定"  onclick ="return OnbuttonGo_click()"  />

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

</ div > 编写相应的JS代码: ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_03ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_04<

script  type ="text/javascript"  language ="JavaScript" > ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05


ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06    function OnbuttonGo_click() 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        requestSimpleService = SimpleWebService.EchoString(

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06            document.getElementById('inputName').value,       //params

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06            OnRequestComplete    //Complete event

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06            );

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        return false;

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06    function OnRequestComplete(result) 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        alert(result);

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_27

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

</ script > 3 ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax<

div >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< asp:ScriptManagerProxy  id ="ScriptManagerProxy1"  runat ="server" >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax        

< Services >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax                    

< asp:ServiceReference  Path ="CalculWebService.asmx"  />

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax         

</ Services >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

</ asp:ScriptManagerProxy >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< h3 > 请输入两个数: </ h3 > &nbsp; < input  id ="inputA"  type ="text"  style ="width: 110px"  /> &nbsp; + &nbsp;

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< input  id ="inputB"  style ="width: 110px"  type ="text"  /> &nbsp;

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< input  id ="buttonEqual"  type ="button"  value =" = "   onclick ="return OnbuttonEqual_click()" />

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

</ div > 编写相应的JS代码:

.运行后界面如下:


ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_asp.net_125

测试Master-Page中的Web Service: ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_126

测试Content-Page中的Web Service: ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_asp.net_127

关于ScriptManagerProxy就介绍到这儿,有个问题就是在我的IDE中为什么ScriptManagerProxy总是提示为未知元素,但运行起来并不抱错,结果也可以出来?

示例代码下载:​​/Files/Terrylee/ASPNETAJAXScriptManagerProxyDemo.rar​

作者: ​​TerryLee​





ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_03ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax_04<

script  type ="text/javascript"  language ="JavaScript" > ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05


ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06    function OnbuttonEqual_click() 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        requestSimpleService = CalculWebService.Add(

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06            document.getElementById('inputA').value,       //params

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06            document.getElementById('inputB').value,       //params

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06            OnRequestComplete    //Complete event

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06            );

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        return false;

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06    function OnRequestComplete(result) 

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_07ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_08    ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_service_05{

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_06        alert(result);

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_脚本_15    }

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_webservice_27

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

</ script > 4



ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax<

asp:ScriptManagerProxy  id ="ScriptManagerProxy1"  runat ="server" >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax    

< Services >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax                

< asp:ServiceReference  Path ="CalculWebService.asmx"  />

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax     

</ Services >

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

ASP.NET AJAX入门系列(3):使用ScriptManagerProxy控件_ajax

</ asp:ScriptManagerProxy > 在它下面可以添加的子标签有:Services,Scripts,AuthenticationService,ProfileService