博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
ajax jsonp跨域
阅读量:6159 次
发布时间:2019-06-21

本文共 2485 字,大约阅读时间需要 8 分钟。

js跨域问题是指:js不同域进行数据传输或通信之间,让我们用ajax到不同的域请求数据。或js获得在不同领域的框架页(iframe)数据。只有到协议、域名、port无论是有不同的,它们被认为是不同的域。

js跨域参考:http://www.cnblogs.com/2050/p/3191744.html
能够通过jsonp实现js跨域,可是获取的数据必须是脚本文件。比如json。
以下介绍jquery.ajax方法
jQuery.ajax(url,[settings]);url是必填的。其它都是选填的。
经常使用格式:
$.ajax({
url:url,
type:"get",
dataType: "jsonp",
sucess:function(data){}
});
主要选项介绍:
1)type:请求方式 ("POST" 或 "GET"),默觉得GET。
2)dataType:
预期server返回的数据类型。

假设不指定,jQuery将自己主动依据HTTP包MIME信息来智能推断,比方XML MIME类型就被识别为XML。在1.4中,JSON就会生成一个JavaScript对象。而script则会运行这个脚本。随后server端返回的数据会依据这个值解析后。传递给回调函数。可用值: 

"xml": 返回 XML 文档。可用 jQuery 处理。
"html": 返回纯文本 HTML 信息;包括的script标签会在插入dom时运行。
"script": 返回纯文本 JavaScript 代码。不会自己主动缓存结果。除非设置了"cache"參数。'''注意:'''在远程请求时(不在同一个域下),全部POST请求都将转为GET请求。

(由于将使用DOM的script标签来载入)

"json": 返回 JSON 数据 。

"jsonp": JSONP 格式。使用 JSONP 形式调用函数时。如 "myurl?callback=?" jQuery 将自己主动替换 ? 为正确的函数名,以运行回调函数。

"text": 返回纯文本字符串
3)async:(默认: true) 默认设置下,全部请求均为异步请求。
假设须要发送同步请求,请将此选项设置为false。

同步请求将锁住浏览器。用户其他操作必须等待请求完毕才干够运行。注意:用jsonp实现跨域。仅仅能使用异步提交,不管你是否设置async。參见:

原文:Cross-domain requests and dataType: "jsonp" requests do not support synchronous operation. Note that synchronous requests may temporarily lock the browser, disabling any actions while the request is active.
4)data:发送到server的数据
data选项既能够包括一个查询字符串,比方 key1=value1&key2=value2 ,也能够是一个映射。比方 {key1: 'value1', key2: 'value2'} 。假设使用了后者的形式,则数据会被转换成查询字符串。
5)jsonp:在一个jsonp请求中重写回调函数的名字。这个值用来替代在"callback=?"这样的GET或POST请求中URL參数里的"callback"部分。比方{jsonp:'onJsonPLoad'}会导致将"onJsonPLoad=?"传给server。

6)jsonpCallback:为jsonp请求指定一个回调函数名。这个值将用来代替jQuery自己主动生成的随机函数名。这主要用来让jQuery生成度独特的函数名。这样管理请求更easy。也能方便地提供回调函数和错误处理。你也能够在想让浏览器缓存GET请求的时候,指定这个回调函数名。
7)username和password选项
假设server须要HTTP认证,能够使用username与password能够通过username和password选项来设置。
8)success(data, textStatus, jqXHR):请求成功后的回调函数。

9)timeout:设置请求超时时间(毫秒)。此设置将覆盖全局设置。

注意。当程序中须要发起多个AJAX请求时,则不用再为每个请求配置请求的參数。全部的选项都能够通过$.ajaxSetup()函数来全局设置
举例:

$.ajaxSetup({    timeout: 3000,    dataType: 'html',    //请求成功后触发    success: function (data) { show.append('success invoke!' + data + '
'); },    //请求失败遇到异常触发    error: function (xhr, status, e) { show.append('error invoke! status:' + status+'
'); },    //完毕请求后触发。即在success或error触发后触发    complete: function (xhr, status) { show.append('complete invoke! status:' + status+'
'); },    //发送请求前触发    beforeSend: function (xhr) {    //能够设置自己定义标头    xhr.setRequestHeader('Content-Type', 'application/xml;charset=utf-8');    show.append('beforeSend invoke!' +'
');    },  })

版权声明:本文博主原创文章。博客,未经同意不得转载。

你可能感兴趣的文章
Matlab 进行FFT
查看>>
Eclipse 工作台用户指导>视图和编辑器
查看>>
项目常用的PHP代码
查看>>
Python自动化开发学习22-Django下(Form)
查看>>
算法-排序
查看>>
获取SQL SERVER某个数据库中所有存储过程的参数
查看>>
在Linux下编译安装Apache2(2)
查看>>
Method Swizzling 处理一类简单的崩溃
查看>>
AngularJS学习!
查看>>
在Eclipse中搭建Python Django
查看>>
struts国际化
查看>>
Laravel 5.0 - Middleware (中间件)
查看>>
文件特殊权限及facl
查看>>
我的友情链接
查看>>
Android按两次返回键退出应用
查看>>
第一章:认识Redhat Linux
查看>>
文本查看指令
查看>>
我的友情链接
查看>>
android开源项目框架大全:《IT蓝豹》
查看>>
我的友情链接
查看>>