jQuery中ajax的使用和缓存问题解决.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
jQuery中ajax的使用和缓存问题解决 jQuery中ajax的使用和缓存问题解决 文章分类:Web前端关键字:jquery中ajax的使用和缓存问题解决 1:GET访问浏览器认为是等幂的 就是一个相同的URL只有一个结果[相同是指整个URL字符串完全匹配] 所以第二次访问的时候如果URL字符串没变化浏览器是直接拿出了第一次访问的结果 POST则认为是一个变动性访问(浏览器认为POST的提交必定是有改变的) 防止GET的等幂访问就在URL后面加上?+new Date();,[总之就是使每次访问的URL字符串不一样的] 设计WEB页面的时候也应该遵守这个原则 2:一.谈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方法处理.例:var url=update.php?username=+encodeURIComponent(username)+content=+encodeURIComponent (content)+id=1; 使用Post方式需注意: 1.设置header的Context-Type为application/x-www-form-urlencode确保服务器知道实体中有参数变量.通常使用XmlHttpRequest对象的SetRequestHeader(Context-Type,application/x-www-form-urlencoded;)。例: xmlHttp.setRequestHeader(Content-Type,application/x-www-form-urlencoded); 2.参数是名/值一一对应的键值对,每对值用号隔开.如var name=abcsex=manage=18,注意var name=update.php? abcsex=manage=18以及var name=?abcsex=manage=18的写法都是错误的; 3.参数在Send(参数)方法中发送,例:xmlHttp.send(name);如果是get方式,直接xmlHttp.send(null); 4.服务器端请求参数区分Get与Post。如果是get方式则$username=$_GET[username];如果是post方式,则$username=$_POST[username]; 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处理的话,也会产生乱码. $.ajax不缓存版: $.ajax({ type:GET url:test.html, cache:false, dataType:html, success:function(msg){ alert(msg); } }); jQuery.ajax(options):通过HTTP请求加载远程数据 这个是jQuery的底层AJAX实现。简单易用的高层实现见$.get,$.post等。 $.ajax()返回其创建

文档评论(0)

iuad + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档