jsonp和ajax的区别是什么

区别:1、ajax的核心是通过xmlHttpRequest获取非本页内容,而jsonp的核心是动态添加script标签调用服务器提供的js脚本;2、jsonp只支持get请求,而ajax支持get和post请求。

jsonp和ajax的区别是什么

本教程操作环境: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的区别是什么的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2939852.html

(0)
上一篇 2025年3月11日 21:39:12
下一篇 2025年3月11日 21:39:21

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • ajax怎么将异步请求改为同步

    AJAX中根据async值的不同可分为同步和异步,默认情况下async值是true(异步提交);而想将异步改为同步,只需要将async的值设置为false即可。 本教程操作环境:windows7系统、javascript1.8.5版、Del…

    2025年3月11日
    200
  • ajax是干什么的

    AJAX是一种用于创建快速动态网页的技术,可以用来:1、做局部请求以实现局部刷新(不刷新页面而更新网页);2、在页面加载后从服务器请求数据;3、在页面加载后从服务器接收数据;4、在后台向服务器发送数据。 本教程操作环境:windows7系统…

    2025年3月11日
    200
  • ajax请求的状态码有哪些

    ajax请求的状态码有:100(继续)、101(切换协议)、200(成功)、201(已创建)、205(重置内容)、301(永久移动)、400(错误请求)、401(未授权)、403(禁止)、500(服务器内部错误)、502(错误网关)等等。 …

    2025年3月11日
    200
  • ajax请求返回类型有哪些

    ajax请求返回类型有:1、xml类型,可用jQuery处理;2、html类型(纯文本HTML信息);3、script类型(纯文本JavaScript代码);4、json类型;5、jsonp类型;6、text类型(纯文本字符串)。 本教程操…

    2025年3月11日
    200
  • http和ajax的区别是什么

    区别:1、AJAX通过xmlHttpRequest对象请求服务器,而http请求通过httpRequest对象请求服务器;2、AJAX请求头会多一个“x-requested-with”参数,值为“XMLHttpRequest”。 本教程操作…

    2025年3月11日
    200
  • ajax的交互模型是什么

    ajax的交互模型是:1、用户发出异步请求;2、利用onReadyStateChange监听;3、创建请求,用open方法指定是get还是post,是否异步,url地址;4、发送请求;5、接受结果并分析;6、实现刷新。 本教程操作环境:wi…

    2025年3月11日
    200
  • ajax叫什么

    ajax全称叫“Asynchronous Javascript And XML”,即“异步JavaScript和XML”,是一种用于创建更好更快以及交互性更强的Web应用程序的技术;使用Ajax能在不更新整个页面的前提下维护数据。 本教程操…

    2025年3月11日
    200
  • ajax的错误码有哪些

    ajax错误码有:400(错误请求)、401(未授权)、403、404、405、406、407、408(请求超时)、409、410、411、412、500(服务器内部错误)、502(错误网关)、503(服务器不可用)、504(网关超时)等。…

    2025年3月11日
    200
  • ajax()中data参数是什么意思

    在ajax中,data的意思为“数据”,该参数用于规定要发送到服务器的数据,会将数据自动转换为请求字符串格式;如果是GET请求,就会将要发送数据附加在URL后。 本教程操作环境:windows7系统、jquery1.10.2版本、Dell …

    2025年3月11日
    200
  • ajax是js吗

    ajax不是js。js全称JavaScript,是一种编程语言;而ajax不是编程语言,是基于javascript的一种用于创建快速动态网页的技术,是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。 本教程操作环境:window…

    2025年3月11日
    200

发表回复

登录后才能评论