欧美三区四区_av先锋影音资源站_亚洲第一论坛sis_影音先锋2020色资源网_亚洲精品社区_在线免费观看av网站_国产一区二区伦理_亚洲欧美视频一区二区_99视频精品全部免费在线_精精国产xxxx视频在线

如何不用組件實現Ajax效果_AJAX教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:ajax跨域訪問代理文件下載(asp、php、asp.net)
最近做東西遇到了ajax跨域(cross domain)訪問的問題,最后采用了Application Proxies 方式解決,即在本域內放置一個代理文件(視本域支持的開發語言選定asp、asp.net或是其他),此代理文件將url參數(QueryString)發送到目標域對應頁面獲取html代碼,然

現在.NET的Ajax組件確實不少了,微軟的ajax extensions用起來很方便,一個UpdatePanel就可以搞定一切。不過,可能有些朋友更愿意自己來寫。那么在.NET里,你是否知道ICallbackEventHandler呢?

大家應該都知道ASP.NET頁面調用時的幾種方式:Postback/Cross-page posting/Server transfer/Callback,如果你還不太了解,你可以看看MSDN:How t Determine How ASP.NET Web Pages Were Invoked

現在要說的,就是Callback這種調用方式。
簡單的說,使用Callback可以得到你平?吹侥敲碅jax效果,即不刷新整個頁面,只更新其中一個部分。

使用Callback,只需要做以下4步:

1、在你的頁面中繼承System.Web.UI.ICallbackEventHandler接口。

public partial class _Default : System.Web.UI.Page, System.Web.UI.ICallbackEventHandler
{
protected void Page_Load(object sender, EventArgs e)
{
}
#region ICallbackEventHandler Members
public string GetCallbackResult()
{
}
public void RaiseCallbackEvent(string eventArgument)
{
}
#endregion
}

如果你沒有使用code-behind,那你也可以在aspx頁面頂部加入下面的代碼:

<%@ Implements Interface="System.Web.UI.ICallbackEventHandler" %>

2、在前臺寫一段自定義的javascript,更新頁面

這一段javascript用來更新頁面的某個局部,就像你平常操作的一樣,寫些document.getElementById("xxx").innerHTML="working on your request...."。

<script type="text/javascript">
function GetFlag(arg)//這里已經得到服務器端數據據了,服務器端數據就在這個參數arg里。
{
document.getElementById("result").innerHTML=arg;//我們不作處理,直接顯示在頁面上。
}
</script>

你可能有些迷糊,就得到了嗎?連個什么XMLHttpRequest都沒有哩……

3、在Page_Load中再注冊一段javascript

string script = Page.ClientScript.GetCallbackEventReference(this, "arg", "GetFlag", "");
Page.ClientScript.RegisterClientScriptBlock(this.GetType(), .......//省略了一大串

上面的GetCallbackEventReference是用來得到客戶端函數的引用,發起一個callback到服務器端的,你不必知道詳細內容。

你只需要了解:

  • 第一個參數填this,用來handle客戶端的callback的,它必須繼承ICallbackEventHandler接口并提供RaiseCallbackEvent方法,我們已經在繼承了這個接口,上面第一點中的代碼也有RaiseCallbackEvent方法,只是還沒有具體寫內容呢。
  • 第二個參數就是那個 從客戶端傳到服務器端的參數。如果你想要注冊的檢查用戶是否可用,那么這里的值就是用戶輸的那個值。
  • 第三個參數是前臺的javascript函數名,在第二步中我們寫的名字是:GetFlag。當數據好了,這個javascript函數就會用到。
  • 第四個參數一般用不上。

返回值:一個函數的名字,是客戶端調用的函數名。這個函數會調用到服務器端了。

4、調用你的函數。

<input type="button" value="check it!" onclick="callServer()" />

上面一定是 onclick="callServer()"嗎?呵呵,這要看你了,你在Page.ClientScript.RegisterClientScriptBlock注冊的什么javascript函數名字,就是什么名字了。(在第3步的第二行code中)

已經完了。如果你還是一頭霧水,沒關系,下面看一個實例

我們寫一個檢測用戶是否已經注冊的小程序,這在每個用戶注冊頁面上都可以用到。

前臺Default.aspx:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" EnableViewState="false" %>
<!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>ICallbackEventHandler Demo</title>
<style type="text/css">
*{font: 12px "verdana";}
#user{border:1px solid #080; height:50px;width:500px;padding:20px;}
input{border:1px solid #508FCC;background:#FFF;}
.ok{color:#090;}
.bad{color:#F00}
#result{display:inline;margin: 0 5px 0;}
</style>
<script type="text/javascript">
function GetFlag(arg)//這里的javascript函數就是服務器查詢完成要調用的函數,我們把服務器返回的數據直接顯示上ID為result的div中。
{
document.getElementById("result").innerHTML=arg;
}
</script>
</head>
<body>
<form id="form1" runat="server">
<div id="user">
<input type="text" value="99love" maxlength="10" id="userid" />
<input type="button" value="check it!" onclick="callServer()" /><div id="result">查詢用戶是否被使用。</div>
</div>
</form>
</body>
</html>

上面有一個<input type="button" value="check it!" onclick="callServer()" />,這是我說的第5步的內容,這個函數名字callServer應該和Lage_Load中注冊的相對應的。

后臺Default.aspx.cs:

using System;
using System.Data;
using System.Configuration;
using System.Collections;
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, System.Web.UI.ICallbackEventHandler
{
private string _arg = string.Empty;
protected void Page_Load(object sender, EventArgs e)
{
string script = Page.ClientScript.GetCallbackEventReference(this, "arg", "GetFlag", "");//上面的第3步,取得這個客戶端函數名,script的值可能是這樣的:WebForm_DoCallback('__Page',arg,GetFlag,\"\",null,false)
Page.ClientScript.RegisterClientScriptBlock(this.GetType(), "callServer", "\nfunction callServer(){\ndocument.getElementById(\"result\").innerHTML=\"正在檢查 \"+document.getElementById(\"userid\").value+\" 的可用性,請稍候...\";\nvar arg=document.getElementById(\"userid\").value;\n" + script + ";\n}", true);
//上面這一行有點長了,第二個參數最長,看到function callServer()了嗎,這就是和前臺對應的那個函數名<input onclick=XXX,請記得,一定要在callServer函數中加入script的值,也就是上一行的上一行(17行)那個值。注意后面的var arg=...,這個arg和17行的arg是對應的。
}
#region ICallbackEventHandler Members
public string GetCallbackResult()
{
System.Threading.Thread.Sleep(1000);//讓線程睡一會,我們好看效果。這是用來模擬不良網絡狀況的。
return _arg;//返回一個string型,這個string在RaiseCallbackEvent函數中是賦過值的,看下面哦。
}
public void RaiseCallbackEvent(string eventArgument)
{
if (eventArgument.Equals("99love") || eventArgument.Equals("blueidea"))//假設這兩個名字不能注冊,實際操作中,你要是比對數據庫記錄的,我們現在簡化處理了。
_arg = string.Format("<span class=\"bad\">很遺憾,{0} 已被使用。</span>", eventArgument);//要么已經注冊了
else
_arg = string.Format("<span class=\"ok\">恭喜您,{0} 可以注冊。</span>", eventArgument);//要么就可以注冊
}
#endregion
}

運行截圖:

UI設計

 

分享:Ajax教程之簡單應用,檢測用戶名是否存在
客戶端頁面index.html onal.dtd html xmlns=1999/xhtml head titleajax測試用戶名是否存在/title script language=

來源:模板無憂//所屬分類:AJAX教程/更新時間:2010-02-25
相關AJAX教程
亚洲女色av| 国产精品久久国产三级国电话系列 | 欧美激情电影| 一区二区三区在线不卡| 亚洲精品电影久久久| 久久亚洲精品欧美| 亚洲熟女少妇一区二区| 国产精品一区二区三区www| 国产精品 日产精品 欧美精品| 精品日韩一区二区三区| 青青草原成人| 久久久久亚洲天堂| 日韩成人在线电影| 成人永久免费视频| 伊人久久久久久久久久| 欧妇女乱妇女乱视频| www.国产com| 综合一区在线| 在线视频欧美精品| 欧美亚洲在线观看| 精品久久久99| 成人亚洲欧美| 国产成人福利片| 伊人伊成久久人综合网小说| 男人c女人视频| 波多野结衣视频免费观看| 欧美不卡高清| 欧美三级一区二区| 久久99精品久久久久久久久久| www.4hu95.com四虎| 女人抽搐喷水高潮国产精品| 亚洲欧美日韩系列| 国产精品色视频| 天天天干夜夜夜操| 免费观看a视频| 国产一区二区在线电影| 亚洲性av在线| 亚洲中文字幕无码专区| 国产精品无码免费播放| 日本伊人午夜精品| 亚洲美女自拍视频| 久久亚洲综合网| 91香蕉视频污在线观看| 欧美一区二区三区久久| 亚洲午夜日本在线观看| 国产日韩欧美黄色| 18禁裸乳无遮挡啪啪无码免费| 18国产精品| 亚洲欧美激情一区二区| 国产精品男人的天堂| 免费不卡的av| 99这里只有精品视频| 亚洲欧美一区二区三区孕妇| 国产精品美女主播| 欧美另类z0zx974| 黄色不卡一区| 在线观看亚洲专区| 日韩精品一区二区三区外面| 欧产日产国产69| 久久av最新网址| 亚洲精选中文字幕| 欧美成人xxxxx| 亚洲欧洲自拍| 91蜜桃视频在线| 欧美在线一区二区三区四| 黄色短视频在线观看| 卡通动漫国产精品| 精品久久香蕉国产线看观看gif| 国产精品二区二区三区| 国产在线拍揄自揄拍| 精品成人久久| 日韩av综合网站| 成年人免费在线播放| 超碰一区二区| 中文字幕精品一区二区精品绿巨人| 国产精品精品视频| www.涩涩爱| 香蕉综合视频| www久久久| 午夜精品福利影院| 色综合天天综合在线视频| 精品一卡二卡三卡四卡日本乱码| 日韩av黄色片| 精品一区av| 欧美特级限制片免费在线观看| 久久精品日韩精品| 少妇一级淫片免费放中国 | 另类av一区二区| 国产亚洲成精品久久| 国产一级特黄a大片免费| av在线精品| 亚洲国产精品麻豆| 欧美高清性xxxxhdvideosex| 日本黄色中文字幕| 国产精品亚洲专一区二区三区| 欧美黄色片视频| 日本美女高潮视频| 蜜桃精品视频| 精品国产乱码久久久久久虫虫漫画 | 国产黄色小视频在线观看| 成人激情校园春色| 国产精品人人做人人爽| 九九热精品免费视频| 久久激情视频| 欧美精品在线极品| 免费看黄色的视频| 一区二区不卡| 亚洲人成免费电影| 性鲍视频在线观看| 国产亚洲一卡2卡3卡4卡新区 | 素人一区二区三区| 亚洲一卡二卡三卡四卡| 日本不卡一区二区三区在线观看 | 国产精品直播网红| 日本黄色片视频| 极品少妇xxxx偷拍精品少妇| 精品少妇一区二区三区| 日韩精品一区中文字幕| 1204国产成人精品视频| 在线视频欧美精品| 9久久9毛片又大又硬又粗| 性欧美video另类hd尤物| 精品高清一区二区三区| www亚洲国产| 国产成人精品123区免费视频| 亚洲婷婷在线视频| 日日欢夜夜爽一区| 欧美日韩国产精品| 91香蕉视频网址| 亚洲av成人无码网天堂| 亚洲丝袜另类动漫二区| 欧美日韩综合另类| 日本波多野结衣在线| 亚洲视频免费看| 亚洲视频小说| 国产精品亚洲d| 精品成人av一区| 日韩视频 中文字幕| 51一区二区三区| 日韩欧美一区视频| 欧洲精品一区二区三区久久| 玖玖精品一区| 欧美一区二区日韩| 在线观看av的网址| 亚洲18在线| 欧美性受xxxx黑人xyx性爽| 精品少妇一区二区三区在线| 亚洲一区二区三区四区电影| 欧美高清hd18日本| 色播五月综合网| 久久一级电影| 中文字幕亚洲激情| 欧美乱大交做爰xxxⅹ小说| 奇米一区二区三区av| 国产成人精品日本亚洲| 中文字幕一区二区人妻电影| 久久综合九色综合97_久久久| 国产精品视频一区二区三区经| 99精品免费观看| 亚洲精品视频一区二区| a级片一区二区| 哺乳一区二区三区中文视频| 亚洲福利影片在线| 色婷婷精品久久二区二区密| 亚洲精品激情| 国产69精品久久久久久| 中文字幕第四页| 中文一区一区三区高中清不卡| 色爱区成人综合网| 欧美a视频在线| 天天综合网 天天综合色| 777av视频| 欧美88888| 精品国产伦一区二区三区观看说明| 欧美日韩成人高清| 中文国产在线观看| 亚洲人成精品久久久| 亚洲精品资源美女情侣酒店| 久久丫精品国产亚洲av不卡| 奇米影视在线99精品| 成人免费午夜电影| 人妻少妇精品无码专区| 日韩欧美国产激情| 日韩精品视频一二三| 欧美日本三区| 欧美亚洲国产另类| 中文人妻熟女乱又乱精品| www.亚洲激情.com| 欧美日韩精品中文字幕一区二区| japanese23hdxxxx日韩| 亚洲成av人影院| 成人观看免费完整观看| 波多野结衣在线播放一区| 操91在线视频| 免费在线不卡视频| 国产精品久久久久久久岛一牛影视 | 国精产品一品二品国精品69xx | 欧美中文在线视频| 在线视频1卡二卡三卡| 一区二区三区资源| 免费在线激情视频| 在线成人超碰| 日韩**中文字幕毛片| 国产伦一区二区| 欧美性极品xxxx做受| 亚洲午夜精品一区| 精品久久久久久中文字幕人妻最新| 少妇精品久久久| 久久精品男人天堂| 久久国产黄色片| 一区二区在线电影| 久久久国产欧美| 亚洲福利久久| 成人免费看黄网站| www.成人影院| 精品国产免费久久| 又嫩又硬又黄又爽的视频| av激情亚洲男人天堂| 中文精品视频一区二区在线观看| 林ゆな中文字幕一区二区| 日日骚av一区| 天天干天天干天天操| 一区二区高清视频在线观看| 亚洲三级视频网站| 校园春色综合网| 成人免费视频视频在| 91亚洲精品在看在线观看高清| 日韩电影在线观看永久视频免费网站| 黄色香蕉视频在线观看| 欧美极品另类videosde| 国产精品免费观看久久| 亚洲国产片色| 97se国产在线视频| 久久久免费人体| 亚洲午夜国产成人av电影男同| 欧美日韩在线视频免费播放| 亚洲欧洲色图综合| 日韩资源av在线| 日韩在线影视| 午夜免费在线观看精品视频| 国产美女无遮挡永久免费| 欧美三电影在线| 97人妻人人揉人人躁人人| 26uuu亚洲婷婷狠狠天堂| 日韩极品视频在线观看| 黄色精品网站| 国产成人精品福利一区二区三区| 只有精品亚洲| 久久精品亚洲精品| 97人妻精品一区二区三区视频| 欧美三级一区二区| 日韩在线视频免费看| 国产精品国产三级国产a| xxww在线观看| 久久99国内精品| 男女h黄动漫啪啪无遮挡软件| 国产精品国内免费一区二区三区| 国产精品免费视频久久久| 羞羞视频在线观看一区二区| 日韩在线高清视频| 国产乱码久久久| 亚洲精品在线电影| 日本在线观看中文字幕| 欧美视频第一页| 国产精品毛片一区二区| 国产日韩欧美激情| 国产一伦一伦一伦| 国产精品一级黄| 国产片侵犯亲女视频播放| 亚洲美女色禁图| 欧美一区二区三区精美影视| 色中色综合网| 亚洲自拍小视频| 极品束缚调教一区二区网站| 45www国产精品网站| 高清成人在线| 久久人人爽人人爽爽久久| 国产富婆一级全黄大片| 亚洲国产黄色片| 天天操天天干天天摸| 欧美日韩高清在线| 久草中文在线视频| 日韩欧美综合在线视频| 青青青视频在线免费观看| 亚洲欧美日韩中文字幕一区二区三区 | 亚洲承认视频| 久久精品一偷一偷国产| 丰满熟妇乱又伦| 伊人青青综合网站| 亚洲av少妇一区二区在线观看 | 中文字幕高清不卡| 手机av在线网站| 久久综合资源网| 亚洲一二三av| 久久影院视频免费| 亚洲黄色av片| 久久嫩草精品久久久久| 亚洲a级黄色片| 97精品超碰一区二区三区| 中文字幕 91| 94色蜜桃网一区二区三区| 久热精品在线播放| 91免费版在线| 黄色片子免费看| 国产色产综合色产在线视频 | 麻豆视频久久| 国产成人aa精品一区在线播放| 欧美影院视频| 国产精品久久久久久久久久久不卡| 久久久久久亚洲精品美女| 青青草成人在线| 白白在线精品| 成人免费观看a| jvid福利在线一区二区| 国产精品毛片一区视频| 午夜激情久久| 欧美一区国产一区| 日韩av女优在线观看| 狠狠色狠狠色综合日日tαg| 欧洲成人一区二区| 亚洲毛片网站| 国产制服91一区二区三区制服| 日韩主播视频在线| 人妻久久久一区二区三区| 国产乱码精品一区二区三区忘忧草 | 手机亚洲手机国产手机日韩| 久久久www免费人成黑人精品| 综合久久久久| 国产高清免费在线| 久久国产精品72免费观看| 红桃av在线播放| 97久久超碰国产精品| 大桥未久恸哭の女教师| 一级精品视频在线观看宜春院| 日本伦理一区二区三区| 在线观看av一区二区| 探花视频在线观看| 亚洲女人天堂视频| av女名字大全列表| 97人人模人人爽人人喊中文字| jizz国产精品| av一区二区三区免费| 欧美日一区二区在线观看| 中文字幕乱码免费| 国产美女在线精品| 色男人天堂av| 亚洲综合一区二区精品导航| 加勒比婷婷色综合久久| 日韩一区二区影院| www.色播.com| 高清欧美电影在线| 亚洲理论电影片| 日韩视频专区| 免费观看在线综合色| 91女神在线观看| 亚洲欧美一区二区三区久本道91 | 久久噜噜亚洲综合| 玖玖爱在线观看| 欧美午夜电影网| 国产又粗又猛又爽又黄视频 | 天堂网一区二区三区| 日韩第一页在线| 欧美不卡高清一区二区三区| 国产精品视频大全| 欧美1区2区视频| 无码中文字幕色专区| 久久众筹精品私拍模特| 亚洲天堂久久新| 欧美日韩激情一区二区| 国产suv一区二区| 午夜精品一区二区三区av| 久久av免费看| 亚洲一区二三| 成人在线视频首页| 国产国语性生话播放| 欧美日韩视频不卡| 亚洲国产剧情在线观看| 97超级碰碰碰| 久久国产成人精品| 毛片av在线播放| 国产三级精品三级| 日本一级二级视频| 日韩乱码在线视频| 日韩黄色三级在线观看| 高清视频一区| 日本视频免费一区| 制服.丝袜.亚洲.中文.综合懂| 欧美性色视频在线| 国产日韩在线观看一区| 欧美在线视频网| 欧美福利影院| 日本www高清视频| 一区二区三区蜜桃| 亚洲永久精品在线观看| 久久精品影视伊人网| 午夜精品影视国产一区在线麻豆| 亚洲在线色站| 91啪亚洲精品| 青青草手机视频在线观看| 亚洲午夜性刺激影院|