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

本文介绍了在ASP.NET AJAX中如何使用ScriptManagerProxy控件来分别管理母版页和内容页的不同脚本资源。通过示例展示了如何在母版页使用ScriptManager控件并引用WebService,以及在内容页使用ScriptManagerProxy实现跨页面脚本管理。
在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元素:
[ScriptService]

publicclassSimpleWebService:System.Web.Services.WebService{

publicSimpleWebService(){

//Uncommentthefollowinglineifusingdesignedcomponents

//InitializeComponent();

}


[WebMethod]

publicstringEchoString(Strings)

{
return"Hello"+s;
}


}
CalculWebService.asmx
[ScriptService]

publicclassCalculWebService:System.Web.Services.WebService{

publicCalculWebService(){

//Uncommentthefollowinglineifusingdesignedcomponents

//InitializeComponent();

}



[WebMethod]

publicintAdd(inta,intb){

returna+b;
}

}
2
<div>

<asp:ScriptManagerID="ScriptManager1"runat="server">

<Services>

<asp:ServiceReferencePath="SimpleWebService.asmx"/>

</Services>

</asp:ScriptManager>

<asp:contentplaceholderid="ContentPlaceHolder1"runat="server">

</asp:contentplaceholder>

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

<inputid="inputName"type="text"/>

<inputid="button"type="button"value="确定"onclick="returnOnbuttonGo_click()"/>

</div>
编写相应的JS代码:
<scripttype="text/javascript"language="JavaScript">

functionOnbuttonGo_click()

{
requestSimpleService
=SimpleWebService.EchoString(

document.getElementById('inputName').value,
//params

OnRequestComplete
//Completeevent

);

returnfalse;
}


functionOnRequestComplete(result)

{
alert(result);
}


</script>
3
<div>

<asp:ScriptManagerProxyid="ScriptManagerProxy1"runat="server">

<Services>

<asp:ServiceReferencePath="CalculWebService.asmx"/>

</Services>

</asp:ScriptManagerProxy>

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

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

<inputid="buttonEqual"type="button"value="="onclick="returnOnbuttonEqual_click()"/>

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

.运行后界面如下:

测试Master-Page中的Web Service:
测试Content-Page中的Web Service:
关于ScriptManagerProxy就介绍到这儿,有个问题就是在我的IDE中为什么ScriptManagerProxy总是提示为未知元素,但运行起来并不抱错,结果也可以出来?
<scripttype="text/javascript"language="JavaScript">

functionOnbuttonEqual_click()
{
requestSimpleService
=CalculWebService.Add(

document.getElementById('inputA').value,
//params

document.getElementById('inputB').value,
//params

OnRequestComplete
//Completeevent

);

returnfalse;
}


functionOnRequestComplete(result)

{
alert(result);
}


</script>
4
<asp:ScriptManagerProxyid="ScriptManagerProxy1"runat="server">

<Services>

<asp:ServiceReferencePath="CalculWebService.asmx"/>

</Services>

</asp:ScriptManagerProxy>
在它下面可以添加的子标签有:Services,Scripts,AuthenticationService,ProfileService
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值