AJAXʵ¼ùDWRƪ
DWR(Direct Web Remoting)ÊÇÒ»¸öWEBÔ¶³Ìµ÷Óÿò¼Ü.ÀûÓÃÕâ¸ö¿ò¼Ü¿ÉÒÔÈÃAJAX¿ª·¢±äµÃºÜ¼òµ¥.ÀûÓÃDWR¿ÉÒÔÔÚ¿Í»§¶ËÀûÓÃJavaScriptÖ±½Óµ÷Ó÷þÎñ¶ËµÄJava·½·¨²¢·µ»ØÖµ¸øJavaScript¾ÍºÃÏñÖ±½Ó±¾µØ¿Í»§¶Ëµ÷ÓÃÒ»Ñù(DWR¸ù¾ÝJavaÀàÀ´¶¯Ì¬Éú³ÉJavaScrip´úÂë).ËüµÄ×îа汾DWR0.6Ìí¼ÓÐí¶àÌØÐÔÈç:Ö§³ÖDom TreesµÄ×Ô¶¯ÅäÖÃ,Ö§³ÖSpring(JavaScriptÔ¶³Ìµ÷ÓÃspring bean),¸üºÃä¯ÀÀÆ÷Ö§³Ö,»¹Ö§³ÖÒ»¸ö¿ÉÑ¡µÄcommons-loggingÈռDzÙ×÷.
ÒÔÉÏÕª×Ôopen-open£¬¿´Á˼¸Ì죬ȷʵÊÇÒ»¸ö·Ç³£ÓÅÐãµÄÏîÄ¿£¬Ëüͨ¹ý·´É䣬½«java·Òë³Éjavascript£¬È»ºóÀûÓûص÷»úÖÆ£¬ÇáËÉʵÏÖÁËjavascriptµ÷ÓÃJava´úÂë¡£
Æä´ó¸Å¿ª·¢¹ý³ÌÈçÏ£º
1.±àдҵÎñ´úÂ룬¸Ã´úÂëÊǺÍdwrÎ޹صġ£
2.È·ÈÏÒµÎñ´úÂëÖÐÄÄЩÀà¡¢ÄÄЩ·½·¨ÊÇÒªÓÉjavascriptÖ±½Ó·ÃÎʵġ£
3.±àдdwr×é¼þ£¬¶Ô²½Öè2µÄ·½·¨½øÐзâ×°¡£
4.ÅäÖÃdwr×é¼þµ½dwr.xmlÎļþÖУ¬Èç¹ûÓбØÒª£¬ÅäÖÃconvert£¬½øÐÐjavaºÍjavascriptÀàÐÍ»¥×ª¡£
5.ͨ¹ý·´Éä»úÖÆ£¬dwr½«²½Öè4µÄÀàת»»³Éjavascript´úÂ룬Ìṩ¸øÇ°Ì¨Ò³Ãæµ÷Óá£
5.±àÐ´ÍøÒ³£¬µ÷Óò½Öè5µÄjavascriptÖеÄÏà¹Ø·½·¨£¨¼ä½Óµ÷Ó÷þÎñÆ÷¶ËµÄÏà¹ØÀàµÄ·½·¨£©£¬Ö´ÐÐÒµÎñÂß¼£¬½«Ö´Ðнá¹ûÀûÓûص÷º¯Êý·µ»Ø¡£
6.Ôڻص÷º¯ÊýÖУ¬µÃµ½Ö´Ðнá¹ûºó£¬¿ÉÒÔ¼ÌÐø±àдҵÎñÂß¼µÄÏà¹Øjavascript´úÂë¡£
ÏÂÃæÒÔÓû§×¢²áµÄÀý×Ó£¬À´ËµÃ÷ÆäʹÓᣣ¨×¢Ò⣬±¾´ÎÀý×ÓÖ»ÊÇÓÃÓÚÑÝʾ£¬ËµÃ÷DWRµÄʹÓã¬ÀàÉè¼Æ²¢²»ÊÇ×îÓŵģ©¡£
1.ÏȽéÉÜÏÂÏà¹ØµÄJavaÀà
User: Óû§À࣬
public class User {
//µÇ½ID£¬Ö÷¼üΨһ
private String id;
//ÐÕÃû
private String name;
//¿ÚÁî
private String password;
//µç×ÓÓʼþ
private String email;
//ÒÔϰüº¬getXXXºÍsetXXX·½·¨
.......
}
UserDAO£ºÊµÏÖUserµÄÊý¾Ý¿â·ÃÎÊ£¬ÕâÀï×÷Ϊһ¸öÑÝʾ£¬±àд²âÊÔ´úÂë
public class UserDAO {
//´æ·Å±£´æµÄÊý¾Ý
private static Map dataMap = new HashMap();
//³Ö¾ÃÓû§
public boolean save(User user) {
if (dataMap.containsKey(user.getId()))
return false;
System.out.println("ÏÂÃæ¿ªÊ¼±£´æÓû§");
System.out.println("id£º"+user.getId());
System.out.println("password£º"+user.getPassword());
System.out.println("name£º"+user.getName());
System.out.println("email£º"+user.getEmail());
dataMap.put(user.getId(), user);
System.out.println("Óû§±£´æ½áÊø");
return
Ïà¹ØÎĵµ£º
Êý¾Ý±íwords½á¹¹
CREATE TABLE `words` ( & ......
AJAXÊÇWEB2.0µÄ»ùʯ£¬ÏÖÔÚÍøÉÏÁ÷Ðм¸ÖÖ¿ªÔ´µÄAJAX¿ò¼Ü£¬±ÈÈ磺jQuery,Mootools,Dojo,Ext JSµÈµÈ¡£
ÈÃÎÒÃÇÀ´¿´¿´Ñ¡ÔñAJAX¿ò¼ÜµÄ»ù´¡£º
¡ôÄãµÄÏîÄ¿ÐèÇ󣨼´ÄãÐèÒªÄÄÐ©ÌØÐÔ£¬ÀýÈçÊÇ·ñÒªÇó×ö³ö¾«ÃÀµÄ½çÃæ¡¢ÌØÐ§»òÆäËü¹¦ÄÜ£©
¡ôÊÇ·ñÖ§³ÖAµÈ¼¶µÄä¯ÀÀÆ÷£¨IE, FirefoxµÈ£©?
¡ôÎĵµµÄÖÊÁ¿£ºÊÇ·ñÍêÉÆ£¨°üº¬½Ì³Ì£¬API£¬´úÂëʾÀýµÈ ......
²ÉÓÃAjax´«µÝ²ÎÊý¼ÓºÅ(+)ºÍÓë·ûºÅ(&)ʱºò£¬·þÎñ¶Ë»ñÈ¡µ½µÄ²ÎÊý²¢²»ÈçÒ⣡
(1) "+"ºÅ£ºJavaScript½âÎöΪ×Ö·û´®Á¬½Ó·û£¬ËùÒÔ·þÎñÆ÷¶Ë½ÓÊÕÊý¾Ýʱ"+"»á¶ªÊ§¡£
(2)"&"£ºJavaScript½âÎöΪ±äÁ¿Á¬½Ó·û£¬ËùÒÔ·þÎñÆ÷¶Ë½ÓÊÕÊý¾Ýʱ&·ûºÅÒÔºóµÄÊý¾Ý¶¼»á¶ªÊ§¡£
½â¾ö°ì·¨£ºÔÚ´«µ½·þÎñ¶Ë֮ǰÏȽ«²ÎÊýÖеÄ"+"ºÍ"&"·ûºÅ¶¼± ......
//´´½¨XMLHttpRequest¶ÔÏó£¬ÐèÒª¸ù¾ÝIEºÍä¯ÀÀÆ÷ÀàÐÍ´´½¨²»Í¬µÄxhr¶ÔÏó
var xhrobj;
function check()
{
//»ñÈ¡Îı¾¿òµÄÖµ
var username = document.getElementById("username").value;
if(window.XMLHttpRequest)
{
//Õë¶Ôfirefox£¬Mozilla£¬ie7£¬ie8µÈ
xhrobj = new XMLHttpRequest();
/ ......
$(function(){
new AjaxUpload('file1', {
action: 'uploadpic.asp',
name: 'form1',
data:{act:'uploadfile',FormName:'form1'},
autoSubmit:false,
responseType:'json',
onSubmit:function(file,ext){
if (!(ext && /^(jpg|png|gif)$/i.test(ext))){
alert('ÇëÄúÉÏ´« ......