×î½ü¿ªÊ¼ÁËASP.NET AJAXµÄÈ«Ãæѧϰ¡£ÔÚ·þÎñ¶Ë±à³ÌÕâ¿éÖ÷ÒªÓм¸¸ö·þÎñÆ÷¿Ø¼þ¸ºÔð£¬ËûÃÇ·Ö±ðΪ:ScriptManager,Timer,UpdatePanel,UpdateProgress.
ÏÈÀ´ËµËµScriptManager.ËüÓиö·½·¨registerAsyncPostBackControl(¿Ø¼þ)£¬¿ÉÒÔ×¢²áÒ³ÃæÉϵÄÈκοؼþΪÒì²½´«ËÍ°´Å¥¡£»¹Óиö·½·¨½ÐAsyncPostBackErrorµÄÀ´×Å£¬ÔÚÕâ¸ö·½·¨ÀïÃæ¿ÉÒÔ¶¨ÒåÊôÓÚ×Ô¼ºµÄ´íÎóÏÔʾ·½Ê½¡£
UpdatePanel,Õâ¸ö¿Ø¼þµÄÓ÷¨ÓкܶàÖÖ£¬²¢ÇÒÓм¸¸öÊôÐÔÊǷdz£ÖØÒªµÄ¡£ËüÃÇ·Ö±ðÊÇ:UpdateMode,ChildrenAsTrigger,Triggers.ͨ¹ýÕ⼸¸öÊôÐÔµÄ×éºÏÄܲúÉúºÜ¶àµÄÒì²½Ò³Ãæ¸üеÄЧ¹û.UpdateModeµÄÖµ¿ÉÒÔΪ:always,conditional;ChildrenAsTriggerµÄÊôÐÔÖµ¿ÉÒÔΪ:True,False.TriggersµÄÊôÐÔֵΪһ¸ö°üº¬Á½ÖÖÀàÐ͵ÄTrigger¼¯ºÏ£¨AysncPostBackTrigger,PostBackTrigger£©.
ÏÖÔÚ¼ÙÉèÓиöUpdatePanel¿Ø¼þ£¬ÎÒÀ´·Ö±ðÉèÖÃÕâЩÊôÐÔÖµµÄ×éºÏ¡£
UpdateMode(always)+ChildrenAsTrigger(true):²»ÂÛÒý·¢Òì²½´«Ë͵ĿؼþÊÇ·ñ·ÅÔÚUpdatePanelÀïÃ棬¸ÃUpdatePanel¶¼»á¸üÐÂ.
&nbs ......
×î½ü¿ªÊ¼ÁËASP.NET AJAXµÄÈ«Ãæѧϰ¡£ÔÚ·þÎñ¶Ë±à³ÌÕâ¿éÖ÷ÒªÓм¸¸ö·þÎñÆ÷¿Ø¼þ¸ºÔð£¬ËûÃÇ·Ö±ðΪ:ScriptManager,Timer,UpdatePanel,UpdateProgress.
ÏÈÀ´ËµËµScriptManager.ËüÓиö·½·¨registerAsyncPostBackControl(¿Ø¼þ)£¬¿ÉÒÔ×¢²áÒ³ÃæÉϵÄÈκοؼþΪÒì²½´«ËÍ°´Å¥¡£»¹Óиö·½·¨½ÐAsyncPostBackErrorµÄÀ´×Å£¬ÔÚÕâ¸ö·½·¨ÀïÃæ¿ÉÒÔ¶¨ÒåÊôÓÚ×Ô¼ºµÄ´íÎóÏÔʾ·½Ê½¡£
UpdatePanel,Õâ¸ö¿Ø¼þµÄÓ÷¨ÓкܶàÖÖ£¬²¢ÇÒÓм¸¸öÊôÐÔÊǷdz£ÖØÒªµÄ¡£ËüÃÇ·Ö±ðÊÇ:UpdateMode,ChildrenAsTrigger,Triggers.ͨ¹ýÕ⼸¸öÊôÐÔµÄ×éºÏÄܲúÉúºÜ¶àµÄÒì²½Ò³Ãæ¸üеÄЧ¹û.UpdateModeµÄÖµ¿ÉÒÔΪ:always,conditional;ChildrenAsTriggerµÄÊôÐÔÖµ¿ÉÒÔΪ:True,False.TriggersµÄÊôÐÔֵΪһ¸ö°üº¬Á½ÖÖÀàÐ͵ÄTrigger¼¯ºÏ£¨AysncPostBackTrigger,PostBackTrigger£©.
ÏÖÔÚ¼ÙÉèÓиöUpdatePanel¿Ø¼þ£¬ÎÒÀ´·Ö±ðÉèÖÃÕâЩÊôÐÔÖµµÄ×éºÏ¡£
UpdateMode(always)+ChildrenAsTrigger(true):²»ÂÛÒý·¢Òì²½´«Ë͵ĿؼþÊÇ·ñ·ÅÔÚUpdatePanelÀïÃ棬¸ÃUpdatePanel¶¼»á¸üÐÂ.
&nbs ......
ÓкܾÃÒ»¶Îʱ¼äÎÒµÄBLOGÉÏûÓгöÏÖAJAXÏà¹ØѶϢÁË£¬Ö÷Òªµ±È»ÊÇÒòΪ¾ø´ó²¿·ÖµÄÖØÐĶ¼·Åµ½ÁËSilverlightÉíÉÏ(¿ÉÔ¤ÆÚµÄδÀ´Ó¦¸ÃÒ²»áÊÇÈç´Ë)¡£
µ«ÓÉÓÚ¹¤×÷ÉϵÄÐèÒª£¬×î½ü»¹ÊÇ»ØÍ·¿´ÁËһϼ´½«ÍƳöµÄASP.NET Ajax Library...£¬Ë³±ãÕÒÁËÒ»ÏÂÍøÂçÉϵÄѶϢ£¬¿´Õâ¸ö̬ÊÆÎÒ²ÂÏëÓ¦¸Ã²»ÉÙASP.NET¿ª·¢ÈËÔ±ºöÂÔµôÁËÕâ¸öÆäʵÒѾbetaºÜ¾Ã¼´½«Ëæ×ÅVS2010ÍƳöµÄJavaScript Library£¬µ±È»£¬Ò²¿ÉÄÜÊÇÒòΪÄúÒѾÔÚʹÓÃjQueryÁË¡£
²»¹ý×Ðϸ¿´¿´ASP.NET Ajax Libraryµ±Öл¹ÊÇÓв»ÉÙ¾«²ÊµÄ¹¦ÄÜ£¬Í¬Ê±ÏÖÔÚ΢ÈíÕë¶ÔAJAX JavaScript LibraryÒ²ÌṩÁËCDN(content delivery network)·þÎñ£¬ÈÃÄú¿ÉÒÔÖ±½ÓÔÚÒ³ÃæÉÏÒýÓÃλÓÚ΢ÈíµÄjavaScriptµµ°¸£¬¶ø²»ÔÙÐèÒª°Ñµµ°¸·ÅÔÚ×Ô¼ºµÄÏîÄ¿ÖС£
ºóÃæÈç¹ûʱ¼äÔÊÐí£¬ÎÒÒ²»á½Ðø½éÉÜASP.NET Ajax LibraryÖеÄһЩ¹¦ÄÜ£¬ÒÔ¼°ºÍjQueryµÄÕûºÏ·½Ê½¡£Ê×ÏÈÀ´¿´ASP.NET Ajax LibraryÖÐClient ControlsµÄʹÓÃ(µ×ϵķ¶ÀýÊÇˮӡµÄTextBox)£º
<head>
<title>Untitled Page</title>
<style type="text/css">
.wm {
color:Gray
}
</style>
<!--從CDNÒýÓÃjs-->
<script sr ......
ÓкܾÃÒ»¶Îʱ¼äÎÒµÄBLOGÉÏûÓгöÏÖAJAXÏà¹ØѶϢÁË£¬Ö÷Òªµ±È»ÊÇÒòΪ¾ø´ó²¿·ÖµÄÖØÐĶ¼·Åµ½ÁËSilverlightÉíÉÏ(¿ÉÔ¤ÆÚµÄδÀ´Ó¦¸ÃÒ²»áÊÇÈç´Ë)¡£
µ«ÓÉÓÚ¹¤×÷ÉϵÄÐèÒª£¬×î½ü»¹ÊÇ»ØÍ·¿´ÁËһϼ´½«ÍƳöµÄASP.NET Ajax Library...£¬Ë³±ãÕÒÁËÒ»ÏÂÍøÂçÉϵÄѶϢ£¬¿´Õâ¸ö̬ÊÆÎÒ²ÂÏëÓ¦¸Ã²»ÉÙASP.NET¿ª·¢ÈËÔ±ºöÂÔµôÁËÕâ¸öÆäʵÒѾbetaºÜ¾Ã¼´½«Ëæ×ÅVS2010ÍƳöµÄJavaScript Library£¬µ±È»£¬Ò²¿ÉÄÜÊÇÒòΪÄúÒѾÔÚʹÓÃjQueryÁË¡£
²»¹ý×Ðϸ¿´¿´ASP.NET Ajax Libraryµ±Öл¹ÊÇÓв»ÉÙ¾«²ÊµÄ¹¦ÄÜ£¬Í¬Ê±ÏÖÔÚ΢ÈíÕë¶ÔAJAX JavaScript LibraryÒ²ÌṩÁËCDN(content delivery network)·þÎñ£¬ÈÃÄú¿ÉÒÔÖ±½ÓÔÚÒ³ÃæÉÏÒýÓÃλÓÚ΢ÈíµÄjavaScriptµµ°¸£¬¶ø²»ÔÙÐèÒª°Ñµµ°¸·ÅÔÚ×Ô¼ºµÄÏîÄ¿ÖС£
ºóÃæÈç¹ûʱ¼äÔÊÐí£¬ÎÒÒ²»á½Ðø½éÉÜASP.NET Ajax LibraryÖеÄһЩ¹¦ÄÜ£¬ÒÔ¼°ºÍjQueryµÄÕûºÏ·½Ê½¡£Ê×ÏÈÀ´¿´ASP.NET Ajax LibraryÖÐClient ControlsµÄʹÓÃ(µ×ϵķ¶ÀýÊÇˮӡµÄTextBox)£º
<head>
<title>Untitled Page</title>
<style type="text/css">
.wm {
color:Gray
}
</style>
<!--從CDNÒýÓÃjs-->
<script sr ......
AJAXÎÞÒÉÊÇ2005Äê³´µÄ×îÈȵÄWeb¿ª·¢¼¼ÊõÖ®Ò»£¬µ±È»£¬Õâ¸ö¹¦ÀÍÀë²»¿ªGoogle¡£ÎÒÖ»ÊÇÒ»¸öÆÕͨ¿ª·¢Õߣ¬Ê¹ÓÃAJAXµÄµØ·½²»ÊÇÌرð¶à£¬ÎҾͼòµ¥µÄ°ÑÎÒʹÓõÄÐĵÃ˵һÏ¡££¨±¾ÎļÙÉèÓû§ÒѾ¾ßÓÐJavaScript¡¢HTML¡¢CSSµÈ»ù±¾µÄWeb¿ª·¢ÄÜÁ¦£©
¡¡¡¡[AJAX½éÉÜ]
¡¡¡¡AjaxÊÇʹÓÿͻ§¶Ë½Å±¾ÓëWeb·þÎñÆ÷½»»»Êý¾ÝµÄWebÓ¦Óÿª·¢·½·¨¡£WebÒ³Ãæ²»Óôò¶Ï½»»¥Á÷³Ì½øÐÐÖØмӲ㬾ͿÉÒÔ¶¯Ì¬µØ¸üС£Ê¹ÓÃAjax£¬Óû§¿ÉÒÔ´´½¨½Ó½ü±¾µØ×ÀÃæÓ¦ÓõÄÖ±½Ó¡¢¸ß¿ÉÓᢸü·á¸»¡¢¸ü¶¯Ì¬µÄWebÓû§½çÃæ¡£
¡¡¡¡Òì²½JavaScriptºÍXML£¨AJAX£©²»ÊÇʲôм¼Êõ£¬¶øÊÇʹÓü¸ÖÖÏÖÓм¼Êõ——°üÀ¨¼¶ÁªÑùʽ±í£¨CSS£©¡¢JavaScript¡¢XHTML¡¢XMLºÍ¿ÉÀ©Õ¹ÑùʽÓïÑÔת»»£¨XSLT£©£¬¿ª·¢Íâ¹Û¼°²Ù×÷ÀàËÆ×ÀÃæÈí¼þµÄWebÓ¦ÓÃÈí¼þ¡£
¡¡¡¡[AJAXÖ´ÐÐÔÀí]
¡¡¡¡Ò»¸öAjax½»»¥´ÓÒ»¸ö³ÆΪXMLHttpRequestµÄJavaScript¶ÔÏó¿ªÊ¼¡£ÈçͬÃû×ÖËù°µÊ¾µÄ£¬ËüÔÊÐíÒ»¸ö¿Í»§¶Ë½Å±¾À´Ö´ÐÐHTTPÇëÇ󣬲¢ÇÒ½«»á½âÎöÒ»¸öXML¸ñʽµÄ·þÎñÆ÷ÏìÓ¦¡£Ajax´¦Àí¹ý³ÌÖеĵÚÒ»²½ÊÇ´´½¨Ò»¸öXMLHttpRequestʵÀý¡£Ê¹ÓÃHTTP·½·¨£¨GET»òPOST£©À´´¦ÀíÇëÇ󣬲¢½«Ä¿±êURLÉèÖõ½XMLHttpRequest¶ÔÏóÉÏ¡£
¡¡¡¡µ±Äã·¢ËÍHTTPÇëÇó£¬Ä㲻ϣÍûä¯ÀÀÆ÷¹ÒÆ𲢵ȴý·þÎñÆ÷µÄÏìÓ¦£¬È ......
AJAXÎÞÒÉÊÇ2005Äê³´µÄ×îÈȵÄWeb¿ª·¢¼¼ÊõÖ®Ò»£¬µ±È»£¬Õâ¸ö¹¦ÀÍÀë²»¿ªGoogle¡£ÎÒÖ»ÊÇÒ»¸öÆÕͨ¿ª·¢Õߣ¬Ê¹ÓÃAJAXµÄµØ·½²»ÊÇÌرð¶à£¬ÎҾͼòµ¥µÄ°ÑÎÒʹÓõÄÐĵÃ˵һÏ¡££¨±¾ÎļÙÉèÓû§ÒѾ¾ßÓÐJavaScript¡¢HTML¡¢CSSµÈ»ù±¾µÄWeb¿ª·¢ÄÜÁ¦£©
¡¡¡¡[AJAX½éÉÜ]
¡¡¡¡AjaxÊÇʹÓÿͻ§¶Ë½Å±¾ÓëWeb·þÎñÆ÷½»»»Êý¾ÝµÄWebÓ¦Óÿª·¢·½·¨¡£WebÒ³Ãæ²»Óôò¶Ï½»»¥Á÷³Ì½øÐÐÖØмӲ㬾ͿÉÒÔ¶¯Ì¬µØ¸üС£Ê¹ÓÃAjax£¬Óû§¿ÉÒÔ´´½¨½Ó½ü±¾µØ×ÀÃæÓ¦ÓõÄÖ±½Ó¡¢¸ß¿ÉÓᢸü·á¸»¡¢¸ü¶¯Ì¬µÄWebÓû§½çÃæ¡£
¡¡¡¡Òì²½JavaScriptºÍXML£¨AJAX£©²»ÊÇʲôм¼Êõ£¬¶øÊÇʹÓü¸ÖÖÏÖÓм¼Êõ——°üÀ¨¼¶ÁªÑùʽ±í£¨CSS£©¡¢JavaScript¡¢XHTML¡¢XMLºÍ¿ÉÀ©Õ¹ÑùʽÓïÑÔת»»£¨XSLT£©£¬¿ª·¢Íâ¹Û¼°²Ù×÷ÀàËÆ×ÀÃæÈí¼þµÄWebÓ¦ÓÃÈí¼þ¡£
¡¡¡¡[AJAXÖ´ÐÐÔÀí]
¡¡¡¡Ò»¸öAjax½»»¥´ÓÒ»¸ö³ÆΪXMLHttpRequestµÄJavaScript¶ÔÏó¿ªÊ¼¡£ÈçͬÃû×ÖËù°µÊ¾µÄ£¬ËüÔÊÐíÒ»¸ö¿Í»§¶Ë½Å±¾À´Ö´ÐÐHTTPÇëÇ󣬲¢ÇÒ½«»á½âÎöÒ»¸öXML¸ñʽµÄ·þÎñÆ÷ÏìÓ¦¡£Ajax´¦Àí¹ý³ÌÖеĵÚÒ»²½ÊÇ´´½¨Ò»¸öXMLHttpRequestʵÀý¡£Ê¹ÓÃHTTP·½·¨£¨GET»òPOST£©À´´¦ÀíÇëÇ󣬲¢½«Ä¿±êURLÉèÖõ½XMLHttpRequest¶ÔÏóÉÏ¡£
¡¡¡¡µ±Äã·¢ËÍHTTPÇëÇó£¬Ä㲻ϣÍûä¯ÀÀÆ÷¹ÒÆ𲢵ȴý·þÎñÆ÷µÄÏìÓ¦£¬È ......
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/style.css" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>TableKit</title>
</head>
<body>
<div id="content">
<p>¿ÉÒÔµã»÷ÐÞ¸ÄÄÚÈÝ£¬ÊµÊ±ÏÔʾ£¬Ã»ÓдæÈëµ½Êý¾Ý¿â£¬µ÷Õûÿ¸öÁÐµÄ¿í£¬µã»÷±í¸ñÍ·²¿ÅÅÐò£¬ÉýÐòºÍ½µÐò</p>
<p>www.corange.cn </p>
<table class="sortable resizable editable">
<thead>
<tr><th class="sortfirstdesc" id="urgency">Urgency</th><th id="creation-date">Date</th><th id="time">Time</th><th id="title">Title</th><th id="status">Status</th><th id="author">Requested By</th><th id="cost">Cost</th><th id="size">Size</th></tr>
</th ......
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/style.css" />
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>TableKit</title>
</head>
<body>
<div id="content">
<p>¿ÉÒÔµã»÷ÐÞ¸ÄÄÚÈÝ£¬ÊµÊ±ÏÔʾ£¬Ã»ÓдæÈëµ½Êý¾Ý¿â£¬µ÷Õûÿ¸öÁÐµÄ¿í£¬µã»÷±í¸ñÍ·²¿ÅÅÐò£¬ÉýÐòºÍ½µÐò</p>
<p>www.corange.cn </p>
<table class="sortable resizable editable">
<thead>
<tr><th class="sortfirstdesc" id="urgency">Urgency</th><th id="creation-date">Date</th><th id="time">Time</th><th id="title">Title</th><th id="status">Status</th><th id="author">Requested By</th><th id="cost">Cost</th><th id="size">Size</th></tr>
</th ......
ÄÚÈÝÒ³£º
<%@ Page Title="" Language="C#" MasterPageFile="~/Site1.Master" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="ScriptManagerProxyDemo.WebForm1" %>
<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="server">
<script type="text/javascript">
function EchoUserInput() {
var echoElem = $get("EnteredValue");
alert(echoElem);
ScriptManagerProxyDemo.WebService1.EchoInput(echoElem.value, OnSucceeded);
}
function OnSucceeded(result)
{
var RsltElem = $get("Results");
RsltElem.innerHTML=result;
}
</script>
<asp:ScriptManagerProxy ID="Script ......
AJAX Ö¸Òì²½ JavaScript ¼° XML£¨Asynchronous JavaScript And XML£©¡£
ÄúÓ¦µ±¾ß±¸µÄ»ù´¡ÖªÊ¶
ÔÚ¼ÌÐøѧϰ֮ǰ£¬ÄúÐèÒª¶ÔÏÂÃæµÄ֪ʶÓлù±¾µÄÁ˽⣺
HTML / XHTML
JavaScript
AJAX = Òì²½ JavaScript ¼° XML£¨Asynchronous JavaScript and XML£©
AJAX ²»ÊÇÒ»ÖÖеıà³ÌÓïÑÔ£¬¶øÊÇÒ»ÖÖÓÃÓÚ´´½¨¸üºÃ¸ü¿ìÒÔ¼°½»»¥ÐÔ¸üÇ¿µÄ Web Ó¦ÓóÌÐòµÄ¼¼Êõ¡£
ͨ¹ý AJAX£¬ÄúµÄ JavaScript ¿ÉʹÓà JavaScript µÄ XMLHttpRequest ¶ÔÏóÀ´Ö±½ÓÓë·þÎñÆ÷½øÐÐͨÐÅ¡£Í¨¹ýÕâ¸ö¶ÔÏó£¬ÄúµÄ JavaScript ¿ÉÔÚ²»ÖØÔØÒ³ÃæµÄÇé¿öÓë Web ·þÎñÆ÷½»»»Êý¾Ý¡£
AJAX ÔÚä¯ÀÀÆ÷Óë Web ·þÎñÆ÷Ö®¼äʹÓÃÒì²½Êý¾Ý´«Ê䣨HTTP ÇëÇ󣩣¬ÕâÑù¾Í¿ÉʹÍøÒ³´Ó·þÎñÆ÷ÇëÇóÉÙÁ¿µÄÐÅÏ¢£¬¶ø²»ÊÇÕû¸öÒ³Ãæ¡£
AJAX ¿ÉʹÒòÌØÍøÓ¦ÓóÌÐò¸üС¡¢¸ü¿ì£¬¸üÓѺá£
AJAX ÊÇÒ»ÖÖ¶ÀÁ¢ÓÚ Web ·þÎñÆ÷Èí¼þµÄä¯ÀÀÆ÷¼¼Êõ¡£
AJAX »ùÓÚ Web ±ê×¼
AJAX »ùÓÚÏÂÁÐ Web ±ê×¼£º
JavaScript
XML
HTML
CSS
ÔÚ AJAX ÖÐʹÓÃµÄ Web ±ê×¼Òѱ»Á¼ºÃ¶¨Ò壬²¢±»ËùÓеÄÖ÷Á÷ä¯ÀÀÆ÷Ö§³Ö¡£AJAX Ó¦ÓóÌÐò¶ÀÁ¢ÓÚä¯ÀÀÆ÷ºÍƽ̨¡£
AJAX ʹظüÓÅÐãµÄÓ¦ÓóÌÐò
Web Ó¦ÓóÌÐò½Ï×ÀÃæÓ¦ÓóÌÐòÓÐÖî¶àÓÅÊÆ£»ËüÃÇÄܹ»Éæ¼°¹ã´óµÄÓû§£¬ËüÃǸüÒ×°²×°¼°Î¬»¤£¬Ò²¸üÒ׿ª·¢¡£
²»¹ ......