jsonp和ajax的区别是什么
区别:1、ajax的核心是通过xmlHttpRequest获取非本页内容,而jsonp的核心是动态添加script标签调用服务器提供的js脚本;2、jsonp只支持get请求,而ajax支持get和post请求。
本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。
ajax和jsonp的调用方式很像,目的一样,都是请求url,然后把服务器返回的数据进行处理,因此jquery和ext等框架都把jsonp作为ajax的一种形式进行了封装。下面我们来了解一下jsonp和ajax,并介绍一下它们的区别。
一、Ajax工作原理
相当于在用户和服务器之间加了—个中间层(AJAX引擎),使用户操作与服务器响应异步化。对于用户请求ajax引擎会做一些数据验证和数据处理,不是所有请求都提交给服务器,当需要从服务器读取新数据时由Ajax引擎代为向服务器提交请求。AJAX最大优点就是不刷新整个页面的前提下与服务器通信维护数据。
过程:
第一步:创建一个ajax引擎对象,IE6的是new ActiveXObject,其他浏览器是new一个xmlHttpRequest对象;
第二步:调用open方法启动一个请求以备发送,open方法传入三个参数:请求类型,请求url和一个布尔值;
第三步:调用send方法发送;
第四步:处理回调函数onreadystatechange,当readState = 4 (响应数据完成),并且status=200(请求成功)时候处理响应数据。
注意:回调函数要写在open()和send()之前。
二、Jsonp工作原理
动态创建一个script标签,利用script标签src属性访问没有限制来实现跨域。
web客户端通过与调用脚本一样的方式来调用跨域服务器上动态生成的js格式文件(后缀.json),服务器动态生成json文件目的是把客户端需要的数据装入进去。
允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住json数据,这样客户端就可以随意定制自己的函数来自动处理返回数据。
三、Ajax 和 jsonp的区别
-
ajax的核心是通过xmlHttpRequest获取非本页内容;
jsonp的核心是动态添加script标签调用服务器提供的js脚本(后缀.json)。
jsonp是一种方式或者说非强制性的协议,ajax也不一定非要用json格式来传递数据。
jsonp只支持get请求,ajax支持get和post请求。
【相关教程推荐:AJAX视频教程】
以上就是jsonp和ajax的区别是什么的详细内容,更多请关注其它相关文章!
上一篇: 整理分享5种纯CSS实现炫酷的文字效果
下一篇: jquery怎样替换标签里的内容
推荐阅读
-
java语法int和Integer(== 和 equals的区别)
-
C++ —— 非类中使用const定义常量的初始化,以及#define和typedef的区别
-
云火墙与云防火墙的区别是什么
-
微服务和分布式的区别以及微服务框架介绍
-
红米k30t和红米k30i的区别
-
hiberfil.sys是什么文件 PHP中文件读、写、删的操作PHP中对文件和目录操作
-
php中用’,'和用’.'的区别
-
ajax中的json和jsonp详解
-
[转载] spring aop 环绕通知around和其他通知的区别
-
荣耀magicbook14和magicbook15有什么区别 荣耀magicbook14和15的区别对比