jquery的ajax两种写法

 ajax是google第一个在web开发中运用的技术,由于其良好的客户体验而致使了在web开发中风靡全球,ajax全名是asynchronous javascripy and xml,核心思想就是局部刷新。 javascript

如今不少Web开发中都是用jquery封装好的ajax,jquery的ajax有两种写法: html

示范页面: java

<div  class="formBox rebackPwd">
   <form action="repwd.do?method=sendCode" name="sure" method="post">
   <div class="formList">
      <p><label>登陆验证码:</label>
      <input id="cCheckCode" type="text" class="ipt" onblur="checkyzm();" maxlength="4"/>
       <img id="tokenImg" src="<%=basePath%>/getTOKEN.do" />
       <span><a href="javascript:refImg();">看不清楚,换一张</a></span>
      </p>
    <p class="prompt"><span id="sp3"></span></p>
</div>
<div class="formList">
   <p><label>注册的邮箱:</label>
   <input id="userMail" name="userMail" type="text" maxlength="50" class="ipt"  onblur="checkMail();" />
  </p>
</div>
 <div class="formList">
   <p class="prompt" style="height:20px;"> <span id="sp1"></span></p>
   <p class="thg2"><a href="javascript:getNewCode();" class="btn6 w100">获取新密码</a></p>	
 </div>			
</form> </div>


第一种是省略的写法(举个例子,好比咱们登陆网站的时候须要输入验证码这就是用ajax实现的,示例代码): 
//对登录验证码进行非空验证
            var validatCode=false;
                    function checkyzm(){
                var checkCode=$("#cCheckCode").val();
                $("#sp3").text("");	
			    if( checkCode== ""){
				    $("#sp3").text("* 请输入验证码");	  
				    validatCode=false;  
				    $("#sp3").focus();
			    }
			    else{
			    	var params="method=checkCode&code="+checkCode;
                    var url1 = "<%=basePath%>login.do";
                    $.post(url1,params,function(meg){
                        var megs=eval(meg);           
                        if(megs=="0")
                        {
                            $("#sp3").text("* 验证码不正确");
                            validatCode=false;
                        }else{
                    	    validatCode=true;
                        }                   
                    });
	        }		    
            }
不少程序员都喜欢用这种的写法,由于这种写法简单明了,可是严格来讲,这种写法是不可取的。由于这种写法只能处理服务器返回的正确值。可是当服务器返回报错的值时候,它就处理不了。因此通常严格的开发经理都会让程序员按第二种写法来写。


第二种写法: jquery

//检查邮箱和登录验证码,若是正确则提交
//(这里用异步提交,并无用表单提交,规范的写法,增长了错误的时候处理函数)
		function getNewCode()
		{
		   var checkCode=$("#cCheckCode").val();
	            var userMail = $("#userMail").val();		
	           if(checkCode != "" && userMail != "")
		      {
			   checkMail(); //前台校验邮箱
			   if(validatCode && mailState)
			   {
			      // alert(22222);
			  var url = "<%=basePath%>repwd.do";
			 var params="method=changMailRegCode&checkCode=" + checkCode + "&userMail=" + userMail;	
		            $.ajax({
			               type: "POST",
			               url: url,
			               dataType:"json",
			               data:params,
			               success:function(resObj){
						    var megs=eval(resObj);
						    if(megs == 0){
							    $("#sp1").html("* 对不起!该邮箱帐户不存在");
						    }else if(megs == 1){
						    	$("#sp1").html("* 对不起!邮箱未激活,不能重置密码");
						    }else {
							    art.dialog({
								    content: '新密码已发送到邮箱,请查看邮件并激活',
								    ok: function () {
								    	this.title('3秒后跳转到首页').time(3);
								        window.location.href="index3.jsp";
								    },
								    cancelVal: '关闭',
								    cancel: true //为true等价于function(){}
								  });
						     }
						  },
						  error: function(XMLHttpRequest, textStatus, errorThrown) {
		                       //alert(XMLHttpRequest.status); //返回500
		                       // alert(XMLHttpRequest.readyState); //返回4
		                       // alert(textStatus); //返回error
		                        if(XMLHttpRequest.status == 500){
		                            art.dialog({
									    content: '获取新密码出错,请联系管理员'
									     });
		                            }
		                        }
					    });
			    }
			}
			else
			{  
				art.dialog({
			    time: 2,
			    content: '信息不完整!'
			     });
			}
		}
//判断邮件格式是否正确
	function checkMail()
	{
	    var userMail=$("#userMail").val();	
	    if(userMail != "")
	    {
	        var valid = /^.+\@[a-zA-Z0-9\-\.]+\.[a-zA-Z]{2,3}$/;
			var flag = valid.test(userMail)
			if(flag == false)
			{
			   $("#sp1").html("邮箱格式不正确");
			   mailState = false ;
			}
			else
			{
			 	$("#sp1").html("");
			    mailState = true ;
			}
		}
		else
		{
			$("#sp1").html("请输入邮箱");
			mailState = false ;
		}
	}

说白了,其实第二种写法也就是多了个处理服务器返回错误值的函数。这样就不会当服务器报错的时候,页面都没有提示信息。 程序员


有句话说二流的程序员只会处理正确的状况,一流的程序员才会考虑出错的状况。 web

其实最完整的写法是这样的: ajax

$(document).ready(function() {
            jQuery("#clearCac").click(function() {
                jQuery.ajax({
                    url: "/Handle/Do.aspx",
                    type: "post",
                    data: { id: '0' },
                    dataType: "json",
                    success: function(msg) {
                        alert(msg);
                    },
                    error: function(XMLHttpRequest, textStatus, errorThrown) {
                        alert(XMLHttpRequest.status);
                        alert(XMLHttpRequest.readyState);
                        alert(textStatus);
                    },
                    complete: function(XMLHttpRequest, textStatus) {
                        this; // 调用本次AJAX请求时传递的options参数
                    }
                });
            });
        });

附:JQuery.Ajax之错误调试帮助信息   此文比较全面 json

连接: http://www.cnblogs.com/mybest/archive/2011/12/13/2285730.html 服务器

相关文章
相关标签/搜索