前端之家收集整理的这篇文章主要介绍了
JSONP跨域,CORS跨域,Hybrid APP跨域,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
JSONP
jsonp: @H_502_4@function(url,callbackFunc,data) //跨域请求 {
@H_502_4@var data = arguments[2] ? arguments[2] : {};
@H_502_4@if(url != '' && callbackFunc != '') {
$.ajax({
type: 'get',dataType: 'jsonp',url: url,jsonp: "callback",jsonpCallback: callbackFunc,data: data,async: true,success: @H_502_4@function(data) {
console.log('跨域请求成功');
},error: @H_502_4@function() {
console.log('跨域请求失败');
}
});
} @H_502_4@else
alert('URL,回调函数不能为空');
}
@H_502_4@function callbackFunc(res) {
}
echo 'callbackFunc({age:18})';
CORS跨域
前端请求按照正常的AJAX请求即可
目前自己随手测过的可以使用的浏览器有:360,IE8+,chrome
Hybrid APP跨域
request: @H_502_4@function(url,data,callback,type) {
xhr = @H_502_4@new plus.net.XMLHttpRequest();
type = arguments[3] ? arguments[3] : 'GET';
data = arguments[1] ? arguments[1] : '';
xhr.onreadystatechange = @H_502_4@function() {
@H_502_4@switch(xhr.readyState) {
@H_502_4@case 4:
@H_502_4@if(xhr.status == 200) {
callback(JSON.parse(xhr.responseText));
} @H_502_4@else {
alert("xhr请求失败:" + xhr.readyState);
}
@H_502_4@break;
}
}
@H_502_4@switch(type.toUpperCase()) {
@H_502_4@case 'GET':
xhr.open(type,url + '?' + data);
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
xhr.send();
@H_502_4@break;
@H_502_4@case 'POST':
xhr.open(type,url);
xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
xhr.send(data);
@H_502_4@break;
}
}