Ajax 和 WCF 的簡單運用

來源:互聯網
上載者:User

建立立一個web Site ,然後在這個Site中新加一個ajax-enable WCF Service  ,如 名為Service

建立後在AppCode下面就有一個CS檔案 ,另外在根目錄下面有一個SVC檔案,此檔案的指向的後台檔案就是AppCode下的CS檔案

<%@ ServiceHost Language="C#" Debug="true" Service="Service" CodeBehind="~/App_Code/Service.cs" %>

開啟CS檔案,對代碼進行如下修改

using System;using System.Linq;using System.Runtime.Serialization;using System.ServiceModel;using System.ServiceModel.Activation;using System.ServiceModel.Web;[ServiceContract(Namespace = "MyNameSpace")]//這裡定義Class所有命名空間[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Allowed)]public class Service{    [OperationContract] //暴露一個方法    public string  getMessage()    {                return "WCF伺服器返回成功!!";    }}

以上對WCF設定部分完成(其實在Web.config新加了配置system.serviceModel空間的配置資訊)

下面在ASPX頁面調用 :

拉一個ScriptManager ,在裡面加一WCF服務的路徑,代碼如下

  <asp:ScriptManager ID="ScriptManager1" runat="server">        <Services >            <asp:ServiceReference Path="~/Service.svc" />  指定SVC檔案的路徑         </Services>   </asp:ScriptManager>

在同一個頁面的JS代碼如下

<script language="javascript" type="text/javascript">        function ajaxTest() {            MyNameSpace.Service.getMessage(onMethodCompleted); //這裡有好幾個重載了幾個方法,分別用來指明成功或失敗時的回呼函數        }        function onMethodCompleted(results) {        var   inner  = document.getElementById("Show");        inner.innerText =  results;        }    </script>

在aspx頁面拉一個用戶端按鈕 ,指定onclick事件為ajaxTest  這樣當點擊按鈕時, WCF那方法的傳回值將顯示出來...

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.