javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】


Posted in Javascript onDecember 15, 2016

本文实例讲述了javascript和 jQuery中的AJAX技术。分享给大家供大家参考,具体如下:

1.什么是AJAX?

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。

通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

传统的网页(不使用 AJAX)如果需要更新内容,必须重载整个网页页面。

2.AJAX在原生JS中的实现

尽管随着JS框架的盛行,在jQuery中,实现AJAX过程相当简单,但是对于一些不需要加载jQuery这种庞大插件的项目中,还是要采用AJAX的原生实现!

要实现原生JS的AJAX过程,对于高版本浏览器,支持JS中的XMLHttpRequest对象,而低版本的浏览器IE6,IE7不兼容,因此要使用ActiveXObject()对象来实现,兼容各种版本的XMLHttpRequest对象的构建如下:

var xml;
if(window.XMLHttpRequest)
{
  xml=new XMLHttpRequest();
}
else{
  xml=new ActiveXObject("Microsoft.XMLHTTP");
}

对于XMLHttpRequest对象有很多种方法,

(1)xml.readyState:表示请求的状态其中xml.readyState=0表示请求的准备阶段,xml.readyState=1,表示开始发送请求,xml.readyState=2表示服务器已经接收到请求,xml.readyState=3表示服务器正在处理请求,xml.readyState=4表示服务器处理完请求,并将请求返回到客户端。

0 - (未初始化)还没有调用send()方法
1 - (载入)已调用send()方法,正在发送请求
2 - (载入完成)send()方法执行完成,已经接收到全部响应内容
3 - (交互)正在解析响应内容
4 - (完成)响应内容解析完成,可以在客户端调用了

(2)xml.status:表示请求过程中的状态说明,

1xx信息提示:

这些状态代码表示临时的响应。客户端在收到常规响应之前,应准备接收一个或多个 1xx 响应。

2XX表示成功,

3XX重定向

客户端浏览器必须采取更多操作来实现请求。例如,浏览器可能不得不请求服务器上的不同的页面,或通过代理服务器重复该请求。

4xx客户端错误

发生错误,客户端似乎有问题。例如,客户端请求不存在的页面,客户端未提供有效的身份验证信息。

5XX服务器错误

服务器由于遇到错误而不能完成该请求。

(3)用原生JS,实现AJAX中的get请求:

var xml=new XMLhttpRequest();
xml.onreadystatechange=function(){
 if(xml.readyState==4&&xml.status==200)
 {
   var data=JSON.parse(xml.responseText);
  }
  else{
   alert("请求失败");
  }
}
xml.open("get","url","true");//url里面为请求的地址,true表示异步请求
xml.send(null)

(4) 用原生JS实现post请求:

var xml=new XMLhttpRequest();
xml.onreadystatechange=function(){
 if(xml.readyState==4&&xml.status==200)
 {
   var data=JSON.parse(xml.responseText);
 }
 else{
   alert("请求失败");
 }
}
xml.open("post","url","true");//url里面为请求的地址,true表示异步请求
xml.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //设置post请求的请求头
xml.send(null)

为什么要设置请求头信息:

默认情况下,Ajax以content-type:text/plain,方式来提交数据,此时服务器将忽略post实体部分的数据,所以服务器无法获得post请求中的数据。

解决方法:

Content-Type: application/x-www-form-urlencoded

3.AJAX中的跨域技术

(1).跨域的方式有首先是代理访问。<script></script>这个方法可以跨域访问JS等文件,比如说

<script src="www.abc.com/de.php?callback=dosomething"</script>

就像引入JS一样,但是不同的是,JSONP方法跨域需要服务器端语言的配合。

(2).只能用于GET方法的jsonp方法,进行跨域比如我们有

datatype:jsonp
    jsonp:callback

然后加上后台处理即可!~

(3).利用XHR2方法,在后台进行操作从而实现跨域支持IE9以上比如 header("Access-Control-Allow-Origin:*");header("Access-Control-Allow-methods:POST,GET");即可实现跨域,并且我们会有在*里面的是允许跨域的地址来源!~

(4).document.domain来跨域

document.domain在需要进行跨域的iframe中,加上相同的document.domain,xxx.com

4.下面主要介绍JSONP和CORS跨域访问解决办法

(1)首先对于JSONP跨域:因为AJAX本身是不能跨域的,有同源保护策略,但是带有src的标签可以跨域

比如<script>和<img>等标签,可以实现跨域请求,这里主要介绍jQuery中JSONP方法的跨域实现:

JSONP的实现思路:

1.前端创建script标记,设置src,添加到head中(你可以往body中添加)

2.后台返回一个js变量jsonp,这个jsonp就是请求后的JSON数据

3.回调完成后删除script标记(还有一些清理工作如避免部分浏览器内存泄露等)

$.ajax({
 type : "get",
 async:false,
 url : "ajax.ashx",
 dataType : "jsonp",
 jsonp: "callbackparam",//传递给请求处理程序或页面的
 jsonpCallback:"success_jsonpCallback",//自定义的jsonp回调函数名称
 success : function(json){
 alert(json);
 alert(json[0].name);
 },
})

(2)CORS跨域方法

CORS定义一种跨域访问的机制,可以让AJAX实现跨域访问,CORS允许一个域上的网络应用向另一个域提交跨域访问请求,实现此功能非常简单,只需要由服务器发送一个相应请求即可!比如在PHP中可以写成:

header("Access-Control-Allow-Origin:*");
header("Access-Control-Allow-methods:POST,GET")

在XHR2方法中实现,并且对于IE,只支持IE9以上浏览器

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JS解密入门之凭直觉解
Jun 25 Javascript
Thinkphp模板没有解析直接原样输出的解决方法
Oct 31 Javascript
jQuery基于图层模仿五星星评价功能的方法
May 07 Javascript
javascript实现继承的简单实例
Jul 26 Javascript
简单的jQuery banner图片轮播实例代码
Mar 04 Javascript
从零开始学习Node.js系列教程之设置HTTP头的方法示例
Apr 13 Javascript
sortable+element 实现表格行拖拽的方法示例
Jun 07 Javascript
vscode vue 文件模板的配置方法
Jul 23 Javascript
js中比较两个对象是否相同的方法示例
Sep 02 Javascript
解决layui数据表格排序图标被超出的表头挤出去的问题
Sep 19 Javascript
js实现移动端图片滑块验证功能
Sep 29 Javascript
vant 时间选择器--开始时间和结束时间实例
Nov 04 Javascript
JavaScript常见的五种数组去重的方式
Dec 15 #Javascript
javascript事件捕获机制【深入分析IE和DOM中的事件模型】
Dec 15 #Javascript
手机软键盘弹出时影响布局的解决方法
Dec 15 #Javascript
JS中页面与页面之间超链接跳转中文乱码问题的解决办法
Dec 15 #Javascript
canvas 画布在主流浏览器中的尺寸限制详细介绍
Dec 15 #Javascript
JavaScript实现Fly Bird小游戏
Dec 15 #Javascript
JS中对数组元素进行增删改移的方法总结
Dec 15 #Javascript
You might like
php 启动报错如何解决
2014/01/17 PHP
迁移PHP版本到PHP7
2015/02/06 PHP
PHP版QQ互联OAuth示例代码分享
2015/07/05 PHP
PHP编程中尝试程序并发的几种方式总结
2016/03/21 PHP
php的laravel框架快速集成微信登录的方法
2016/12/12 PHP
TP5框架简单登录功能实现方法示例
2019/10/31 PHP
菜鸟学习JavaScript小实验之函数引用
2010/11/17 Javascript
javascript写的异步加载js文件函数(支持数组传参)
2014/06/07 Javascript
javascript中$(function() {});写与不写有哪些区别
2015/08/10 Javascript
Bootstrap框架实现广告轮播效果
2016/11/28 Javascript
实例分析nodejs模块xml2js解析xml过程中遇到的坑
2017/03/18 NodeJs
使用jQuery 操作table 完成单元格合并的实例
2017/12/27 jQuery
VUE的history模式下除了index外其他路由404报错解决办法
2019/08/21 Javascript
基于Vue.js+Nuxt开发自定义弹出层组件
2020/10/09 Javascript
[01:26]神话结束了,却也刚刚开始——DOTA2新英雄玛尔斯驾临战场
2019/03/10 DOTA
python2.7的编码问题与解决方法
2016/10/04 Python
Python虚拟环境virtualenv的安装与使用详解
2017/05/28 Python
python按综合、销量排序抓取100页的淘宝商品列表信息
2018/02/24 Python
详解Python中的正斜杠与反斜杠
2019/08/09 Python
python数组循环处理方法
2019/08/26 Python
浅谈对python中if、elif、else的误解
2020/08/20 Python
Python爬虫之Selenium鼠标事件的实现
2020/12/04 Python
详解canvas在圆弧周围绘制文本的两种写法
2018/05/22 HTML / CSS
h5网页水印SDK的实现代码示例
2019/02/19 HTML / CSS
约瑟夫·特纳男装:Joseph Turner
2017/10/10 全球购物
德国高品质男装及配饰商城:Cultizm(Raw Denim原色牛仔裤)
2018/04/16 全球购物
REISS美国官网:伦敦最受欢迎的时尚品牌
2019/08/16 全球购物
Unineed中文官网:高端护肤美妆与时尚配饰,英国直邮
2020/07/23 全球购物
施工材料员岗位职责
2014/02/12 职场文书
团支部建设方案
2014/05/02 职场文书
社区矫正工作方案
2014/06/04 职场文书
医学求职自荐信
2014/06/21 职场文书
2015年图书馆个人工作总结
2015/05/26 职场文书
AI:如何训练机器学习的模型
2021/04/16 Python
HTML通过表单实现酒店筛选功能
2021/05/18 HTML / CSS
小程序wx.getUserProfile接口的具体使用
2021/06/02 Javascript