您好,欢迎访问三七文档
当前位置:首页 > 财经/贸易 > 资产评估/会计 > JavaScript+JQuery
浅谈ajax中get与post的区别,以及ajax中的乱码问题的解决方法文章分类:Web前端一.谈Ajax的Get和Post的区别Get方式:用get方式可传送简单数据,但大小一般限制在1KB下,数据追加到url中发送(http的header传送),也就是说,浏览器将各个表单字段元素及其数据按照URL参数的格式附加在请求行中的资源路径后面。另外最重要的一点是,它会被客户端的浏览器缓存起来,那么,别人就可以从浏览器的历史记录中,读取到此客户的数据,比如帐号和密码等。因此,在某些情况下,get方法会带来严重的安全性问题。Post方式:当使用POST方式时,浏览器把各表单字段元素及其数据作为HTTP消息的实体内容发送给Web服务器,而不是作为URL地址的参数进行传递,使用POST方式传递的数据量要比使用GET方式传送的数据量大的多。总之,GET方式传送数据量小,处理效率高,安全性低,会被缓存,而POST反之。使用get方式需要注意:1对于get请求(或凡涉及到url传递参数的),被传递的参数都要先经encodeURIComponent方法处理.例:varurl=update.php?username=+encodeURIComponent(username)+&content=+encodeURIComponent(content)+&id=1;使用Post方式需注意:1.设置header的Context-Type为application/x-(Context-Type,application/x-)。例:xmlHttp.setRequestHeader(Content-Type,application/x-);2.参数是名/值一一对应的键值对,每对值用&号隔开.如varname=abc&sex=man&age=18,注意varname=update.php?abc&sex=man&age=18以及varname=?abc&sex=man&age=18的写法都是错误的;3.参数在Send(参数)方法中发送,例:xmlHttp.send(name);如果是get方式,直接xmlHttp.send(null);4.服务器端请求参数区分Get与Post。如果是get方式则$username=$_GET[username];如果是post方式,则$username=$_POST[username];Post和Get方法有如下区别:1.Post传输数据时,不需要在URL中显示出来,而Get方法要在URL中显示。2.Post传输的数据量大,可以达到2M,而Get方法由于受到URL长度的限制,只能传递大约1024字节.3.Post顾名思义,就是为了将数据传送到服务器段,Get就是为了从服务器段取得数据.而Get之所以也能传送数据,只是用来设计告诉服务器,你到底需要什么样的数据.Post的信息作为http请求的内容,而Get是在Http头部传输的。get方法用Request.QueryString[strName]接收post方法用Request.Form[strName]接收注意:虽然两种提交方式可以统一用Request(strName)来获取提交数据,但是这样对程序效率有影响,不推荐使用。一般来说,尽量避免使用Get方式提交表单,因为有可能会导致安全问题AJAX乱码问题产生乱码的原因:1、xtmlhttp返回的数据默认的字符编码是utf-8,如果客户端页面是gb2312或者其它编码数据就会产生乱码2、post方法提交数据默认的字符编码是utf-8,如果服务器端是gb2312或其他编码数据就会产生乱码解决办法有:1、若客户端是gb2312编码,则在服务器指定输出流编码2、服务器端和客户端都使用utf-8编码gb2312:header('Content-Type:text/html;charset=GB2312');utf8:header('Content-Type:text/html;charset=utf-8');注意:如果你已经按上面的方法做了,还是返回乱码的话,检查你的方式是否为get,对于get请求(或凡涉及到url传递参数的),被传递的参数都要先经encodeURIComponent方法处理.如果没有用encodeURIComponent处理的话,也会产生乱码.实例:POSTx=false;if(window.XMLHttpRequest){//Mozilla,Safari,...x=newXMLHttpRequest();if(x.overrideMimeType)x.overrideMimeType('text/html');}elseif(window.ActiveXObject){//IEtry{x=newActiveXObject(Msxml2.XMLHTTP);}catch(e){try{x=newActiveXObject(Microsoft.XMLHTTP);}catch(e){}}}if(!x){alert('CannotcreateXMLHTTPinstance');returnfalse;}if(document.getElementById){varx=(window.ActiveXObject)?newActiveXObject(Microsoft.XMLHTTP):newXMLHttpRequest();}if(x){x.onreadystatechange=function(){if(x.readyState==4&&x.status==200){document.getElementById(displayid).innerHTML=x.responseText;document.getElementById(id).innerHTML='';}}if(parametros!='')parameters='ajaxid='+parametros;elseparameters='';url=programa;x.open('POST',url,true);x.setRequestHeader(Content-type,application/x-);x.setRequestHeader(Content-length,parameters.length);x.setRequestHeader(Connection,close);x.send(parameters);}GETx=false;if(window.XMLHttpRequest){//Mozilla,Safari,...x=newXMLHttpRequest();if(x.overrideMimeType)x.overrideMimeType('text/html');}elseif(window.ActiveXObject){//IEtry{x=newActiveXObject(Msxml2.XMLHTTP);}catch(e){try{x=newActiveXObject(Microsoft.XMLHTTP);}catch(e){}}}if(!x){alert('CannotcreateXMLHTTPinstance');returnfalse;}if(document.getElementById){varx=(window.ActiveXObject)?newActiveXObject(Microsoft.XMLHTTP):newXMLHttpRequest();}if(x){x.onreadystatechange=function(){if(x.readyState==4&&x.status==200){document.getElementById(displayid).innerHTML=x.responseText;document.getElementById(id).innerHTML='';}}if(parametros!='')url=programa+'?ajaxid='+parametros;elseurl=programa;x.open(GET,url,true);x.send(null);}05:10浏览(15)评论(0)分类:Javascript(Jquery)2011-01-28缩略显示数据延迟加载文章分类:Web前端看来lazyload.js不能真正的实现数据动态加载了,只是一个样子,其实我们实现动态加载不过是为了减轻服务器的压力而已,lazyload.js显示是个花架子,如何实现真正的动态加载,需要对lazyload.js做改装。我认为,动态加载本质上都是一样的,即:图片或者数据一开始不会被加载,当你触发了滚动条(说明你想继续看这个网站)那么图片或者数据开始加载。那么实现的方法其实有很多,但是基本上都是通过替换的方式来实现的。1.土豆:metahttp-equiv=Content-Typecontent=text/html;charset=utf-8/scripttype=text/javascriptsrc=能看的见到图片:imgsrc==lazyBoxstyle=margin-top:100px;一开始看不到的图片:imgwidth=120height=90style=border:1pxsolidblue;class=lazyImgalt===_DAA/imgwidth=120height=90style=border:1pxsolidblue;class=lazyImgalt===_DBA//divdivstyle=height:1000px;/divscripttype=text/javascriptvarhasShow=false;$(window).bind(scroll,function(){if(hasShow==true){$(window).unbind(scroll);return;}vart=$(document).scrollTop();if(t100){//滚动高度超过100时,加载图片hasShow=true;$(#lazyBox.lazyImg).each(function(){$(this).attr(src,$(this).attr(alt));});}});/script2.微博ajax提取数据!DOCTYPEhtmlPUBLIC-//W3C//DTDXHTML1.0Transitional//EN==Content-T
本文标题:JavaScript+JQuery
链接地址:https://www.777doc.com/doc-5536311 .html