IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類|軟件專題|手機(jī)版|論壇轉(zhuǎn)貼|軟件發(fā)布

您當(dāng)前所在位置:首頁網(wǎng)絡(luò)編程.Net編程 → javascript直接調(diào)用asp.net方法的技術(shù)

javascript直接調(diào)用asp.net方法的技術(shù)

時(shí)間:2015/6/28來源:IT貓撲網(wǎng)作者:網(wǎng)管聯(lián)盟我要評(píng)論(0)

  前言本技術(shù)完全開源,請各位兄弟隨便修改、使用,但是必須能夠保留相關(guān)版權(quán)的說明;我的小小技術(shù)能在您的項(xiàng)目中使用,是我的光榮,希望不要破滅了我僅存的自豪感,衷心感謝,在此鞠躬!

  本技術(shù)主要基于.net 2.0,提供ASP.NET頁面的javascript直接通過ajax調(diào)用服務(wù)端的c#方法,完全打通javascript往asp.net的最后防線。

  本技術(shù)實(shí)在開發(fā)pixysoft.framework.neobes.jsons中用到的一項(xiàng)技術(shù)。而jsons框架主要負(fù)責(zé)面向異構(gòu)網(wǎng)站提供基于jsons的數(shù)據(jù)庫訪問。

  技術(shù)演示aspx頁面簡介:

  <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

  <%@ Register Assembly="Pixysoft.Ajax" Namespace="Pixysoft.Framework.Noebe.Jsons.WebControls"

  TagPrefix="cc1" %>

  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

  <html xmlns="https://www.w3.org/1999/xhtml">

  <head runat="server">

  <title>pixysoft.ajax</title>

  <script type="text/javascript">

  var code=1;

  function ServerMethodCallback(value)

  {

  code = value;

  Message1.innerText = value;

  }

  </script>

  </head>

  <body>

  <form id="form1" runat="server">

  <div>

  <cc1:PixysoftAjaxBase ID="PixysoftAjaxBase1" runat="server" />

  <br />

  result: <span id="Message1">0</span>

  <input type="button" value="讓我們回調(diào)吧!" onclick="ServerMethod(code)" id="Button1" />

  </div>

  </form>

  </body>

  </html>

#p#副標(biāo)題#e#

  后臺(tái)代碼簡介:

  using System;

  using System.Data;

  using System.Configuration;

  using System.Web;

  using System.Web.Security;

  using System.Web.UI;

  using System.Web.UI.WebControls;

  using System.Web.UI.WebControls.WebParts;

  using System.Web.UI.HtmlControls;

  public partial class _Default : System.Web.UI.Page

  {

  protected void Page_Load(object sender, EventArgs e)

  {

  }

  public int ServerMethod(int value)

  {

  return value * 2;

  }

  }

  1. 頁面有個(gè)htmlbutton, 點(diǎn)擊會(huì)激活 ServerMethod這個(gè)方法

  2. 后臺(tái)會(huì)處理這個(gè)方法,回調(diào)頁面的ServerMethodCallback,同時(shí)把運(yùn)算結(jié)果傳入

  3. 運(yùn)行結(jié)果就是不斷結(jié)算 code *2,并顯示在頁面的<span id="Message1">里面。

  4. 如果服務(wù)端的方法不需要返回參數(shù),那么可以不寫ServerMethodCallback.

  教程說明

    1. 首先需要在服務(wù)端聲明一個(gè)public的方法, 例如public int ServerMethod(int value); 可以無返回值.

  2. 在javascript里面直接使用服務(wù)端聲明的方法,例如onclick="ServerMethod(code)" ,區(qū)分大小寫。

  3. 如果服務(wù)端方法有返回值,那么需要在javasccript聲明一個(gè)回調(diào)方法,命名規(guī)則是服務(wù)端方法+Callback,例如:function ServerMethodCallback(value)

  4. 完成

  注意事項(xiàng)

    1. 非常悲哀,調(diào)用過程不支持session / cache 等,就是完全的無狀態(tài)。這是由于asp.net的一個(gè)bug造成的。具體:

  https://connect.microsoft.com/VisualStudio/feedback/ViewFeedback.aspx?FeedbackID=104259

  2. 同樣悲哀,調(diào)用的方法不支持直接執(zhí)行,只能通過event激活,例如一下是個(gè)無效調(diào)用。

  <script>

  int code = 1;

  ServerMethod(code);

  </script>

  這是由于頁面沒有完全加載完畢而調(diào)用的問題,不會(huì)報(bào)錯(cuò),但是沒有效果。

  相關(guān)技術(shù)介紹

    1. 本技術(shù)主要使用了asp.net的回調(diào)技術(shù),ICallbackEventHandler

  2. 結(jié)合了反射原理

  具體就不點(diǎn)明了,各位大俠看看源碼就懂了。

關(guān)鍵詞標(biāo)簽:javascript,asp.net

相關(guān)閱讀

文章評(píng)論
發(fā)表評(píng)論

熱門文章 手把手教你用好LINQ to SQL手把手教你用好LINQ to SQL在.NET環(huán)境下為網(wǎng)站增加IP過濾功能在.NET環(huán)境下為網(wǎng)站增加IP過濾功能ASP.NET 如何避免頁面重新整理時(shí)重復(fù)送出ASP.NET 如何避免頁面重新整理時(shí)重復(fù)送出用Asp.net擴(kuò)展ExtJS用Asp.net擴(kuò)展ExtJS

相關(guān)下載

人氣排行 asp.net表單提交方法GET\POST在ASP.NET中如何判斷用戶IE瀏覽器的版本Asp.net中messagebox的實(shí)現(xiàn)方法Asp.net中的web.config配置在ASP.NET MVC中實(shí)現(xiàn)大文件異步上傳用Iformattable接口控制.Net中文本格式c#.Net經(jīng)典面試題目用Asp.net擴(kuò)展ExtJS