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