欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript 直接調(diào)用服務(wù)器C#代碼 ASP.NET Ajax實(shí)例

 更新時(shí)間:2010年03月08日 19:33:44   作者:  
近來(lái)總有一些朋友會(huì)問(wèn)到一些入門(mén)的問(wèn)題,把這些問(wèn)題整理一下,寫(xiě)出來(lái)。在以前的文章里,曾經(jīng)利用純JS編寫(xiě)過(guò)Ajax引擎,在真正開(kāi)發(fā)的時(shí)候,大家都不喜歡以這種低效率的方式開(kāi)發(fā),利用MS Ajax的集成的引擎,可以簡(jiǎn)單不少工作。

在MS Ajax中,JS與C#交互的一種方式就是調(diào)用WebService,該WebService可以ASMX的也可以是WCF的,不論哪種方式,系統(tǒng)都會(huì)自動(dòng)為開(kāi)發(fā)者生成代理的JS類。實(shí)現(xiàn)方法如下:

1.        建立一個(gè)網(wǎng)站,并在其中添加一個(gè)WCF服務(wù)(這里一定要選擇Ajax-Enabled WCF Service),如下圖所示:

2.        IDE會(huì)自動(dòng)為我們生成一個(gè)SVC文件,是對(duì)外的接口,以及該SVC對(duì)應(yīng)的后臺(tái)實(shí)現(xiàn)類,該類文件會(huì)被放在App_Code下,如下圖所示:

height=99

3.修改該類的代碼,如下所示:

復(fù)制代碼 代碼如下:

[ServiceContract(Namespace = "TestAjax")]
[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]
public class Service
{
[OperationContract]
public bool ValidateUser(string uid, string pwd)
{
if (uid=="sa"&&pwd=="sa")
{
return true;
}
return false;
}
}

4.現(xiàn)在我們就可以頁(yè)面里調(diào)用了,首先在頁(yè)面中添加一個(gè)ScriptManager,并引入我們剛才編寫(xiě)的那個(gè)WCF WebService(目的是在運(yùn)行的時(shí)候生成JS的代理類),如下所示:
復(fù)制代碼 代碼如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:ScriptManager ID="ScriptManager1" runat="server">
<Services>
<asp:ServiceReference Path="~/Service.svc"/>
</Services>
</asp:ScriptManager>
</div>
</form>
</body>
</html>

5.接下來(lái)可以編寫(xiě)JS代碼來(lái)直接調(diào)用C#寫(xiě)的WebService了。JS代碼如下所示:
復(fù)制代碼 代碼如下:

<script type="text/javascript">
function ValidateUser(uid, pwd) {
TestAjax.Service.ValidateUser(uid,pwd,OnSucceed ,OnFailed );
}
function OnSucceed(result) {
if (result == true) {
window.alert("通過(guò)驗(yàn)證");
}
else {
window.alert("驗(yàn)證失??!");
}
}
function OnFailed(result) {
window.alert("操作失?。?+result ._message);
}
</script>

6.這里請(qǐng)大家注意,在調(diào)用TestAjax.Service.ValidateUser方法時(shí),代碼中并沒(méi)有直接取該函數(shù)的返回值,因?yàn)槔眠@種方案對(duì)服務(wù)器函數(shù)的調(diào)用都是異步的,正確的處理方法是指定了兩個(gè)回調(diào)函數(shù)OnSucceed和OnFailed,第一個(gè)函數(shù)是成功時(shí)的回調(diào),后一個(gè)是失敗時(shí)的回調(diào),這兩個(gè)函數(shù)都需要一個(gè)參數(shù),OnSucceed的參數(shù)就是服務(wù)器函數(shù)的返回值,而OnFailed的參數(shù)是失敗時(shí)的出錯(cuò)信息,功能有點(diǎn)像Exception類型,其中_message屬性中出錯(cuò)信息,_stackTrace中出錯(cuò)的堆棧跟蹤信息。
7.千萬(wàn)別說(shuō)這種回調(diào)方法麻煩!其實(shí)這是一種常規(guī)的異步回調(diào)模式,大多數(shù)情況(不論什么語(yǔ)言)都會(huì)這么寫(xiě)的!
8.頁(yè)面上完整的代碼如下所示:
復(fù)制代碼 代碼如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script type="text/javascript">
function ValidateUser(uid, pwd) {
TestAjax.Service.ValidateUser(uid,pwd,OnSucceed ,OnFailed );
}
function OnSucceed(result) {
if (result == true) {
window.alert("通過(guò)驗(yàn)證");
}
else {
window.alert("驗(yàn)證失敗!");
}
}
function OnFailed(result) {
window.alert("操作失敗:"+result ._message);
}
function Button1_onclick() {
var uid = $get("tbxUid").value;
var pwd = $get("tbxPwd").value;
ValidateUser(uid,pwd);
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:ScriptManager ID="ScriptManager1" runat="server">
<Services>
<asp:ServiceReference Path="~/Service.svc"/>
</Services>
</asp:ScriptManager>
</div>
用戶名:<input id="tbxUid" type="text" /><br />
密碼: <input id="tbxPwd" type="text" />
<input id="Button1" type="button" value="驗(yàn)證" onclick="return Button1_onclick()" />
</form>
</body>
</html>

9.運(yùn)行結(jié)果如下所示:
當(dāng)用戶名和密碼都是sa時(shí)會(huì)通過(guò)驗(yàn)證
當(dāng)用戶名和官友有一個(gè)值不是sa時(shí)就不能通過(guò)驗(yàn)證 


10. 大家有什么問(wèn)題給我發(fā)Email吧:warensoft@foxmail.com

相關(guān)文章

最新評(píng)論