1.jsonp方法

转:https://blog.csdn.net/liusaint1992/article/details/50959571

主要实现功能:

1.参数拼装。

2.给每个回调函数唯一命名。

3.在回调成功或请求失败之后删除创建的javascript标签。 需要兼容IE。IE下onerror事件不兼容。这里有对它的模拟实现。在IE下加载失败也能get到。

4.超时功能。超时取消回调。执行error。

5.error事件。可执行自己传入的error事件。

代码封装,调用,以及后台代码如下

/*author:ls <841766635@qq.com>
* data:2016/03/20
*/ function JSONP(url,config){
var data = config.data || [];
var paraArr=[],paraString='';//get请求的参数。
var urlArr;
var callbackName;//每个回调函数一个名字。按时间戳。
var script,head;//要生成script标签。head标签。
var supportLoad;//是否支持 onload。是针对IE的兼容处理。
var onEvent;//onload或onreadystatechange事件。
var timeout = config.timeout || 0;//超时功能。 for(var i in data){
if(data.hasOwnProperty(i)){
paraArr.push(encodeURIComponent(i) + "=" +encodeURIComponent(data[i]));
}
} urlArr = url.split("?");//链接中原有的参数。
if(urlArr.length>1){
paraArr.push(urlArr[1]);
} callbackName = 'callback'+new Date().getTime();
paraArr.push('callback='+callbackName);
paraString = paraArr.join("&");
url = urlArr[0] + "?"+ paraString; script = document.createElement("script");
script.loaded = false;//为了实现IE下的onerror做的处理。JSONP的回调函数总是在script的onload事件(IE为onreadystatechange)之前就被调用了。因此我们在正向回调执行之时,为script标签添加一个属性,然后待到onload发生时,再检测有没有这个属性就可以判定是否请求成功,没有成功当然就调用我们的error。 //将回调函数添加到全局。
window[callbackName] = function(arg){
var callback = config.callback;
callback(arg);
script.loaded = true;
} head = document.getElementsByTagName("head")[0];
head.insertBefore(script, head.firstChild) //chrome下第二个参数不能为null
script.src = url; supportLoad = "onload" in script;
onEvent = supportLoad ? "onload" : "onreadystatechange"; script[onEvent] = function(){ if(script.readyState && script.readyState !="loaded"){
return;
}
if(script.readyState == 'loaded' && script.loaded == false){
script.onerror();
return;
}
//删除节点。
(script.parentNode && script.parentNode.removeChild(script))&& (head.removeNode && head.removeNode(this));
script = script[onEvent] = script.onerror = window[callbackName] = null; } script.onerror = function(){
if(window[callbackName] == null){
console.log("请求超时,请重试!");
}
config.error && config.error();//如果有专门的error方法的话,就调用。
(script.parentNode && script.parentNode.removeChild(script))&& (head.removeNode && head.removeNode(this));
script = script[onEvent] = script.onerror = window[callbackName] = null;
} if(timeout!= 0){
setTimeout(function() {
if(script && script.loaded == false){
window[callbackName] = null;//超时,且未加载结束,注销函数
script.onerror();
}
}, timeout);
} }

  

<!-- jsonp.html-->
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>jsonp测试</title>
<script src="jsonp.js"></script>
</head>
<body>
<script>
function myerror(){
alert('there must be something wrong!');
}
function getData (data){
alert("服务器过来的数据是"+data);
}
var url = 'http://runningls.com/demos/2016/jsonp/jsonp.php';
//调用函数。
JSONP(url,{
data:{
id:1
},
callback:getData,
error:myerror,
timeout:10000
});
</script>
</body>

  

<?php   

$callback = $_GET['callback'];
$id = $_GET['id']; if($id == 1){
$res = 'this is 1';
} if($id == 2){
$res = 'this is 2';
} $res = $callback."('$res')"; echo $res; ?>

  2.hash方法

//利用hash,场景是当前页面A 通过iframe 和frame嵌入跨域的页面B
//在A中伪代码如下:
var B = document。个体ElementsByTagName('iframe');
B.src = B.src + '#' + 'data';
//在B 中的伪代码如下
window.onhashchange = function(){
var data = window.location.hash;
}

  3.postMessage

//窗口A(http:A.com)向跨域的窗口B(http://B.com)发送信息
window.postMessage('data','http://B.com');//B窗口
//在窗口B中监听;
window.addEventListener('message',function(event){
console.log(event.origin); //http://A.com
console.log(event.source);//Bwindow
console.log(event.data); //data
},false);

  4.webSocket方法

//websocket 【 参考质料】(http://www.ruanyifeng.com/blog/2017/05/websocket.html)
var ws = new WebSocket('wss://echo.websocket.org');
ws.onpen = function(evt){
console.log.('Connection open ...');
ws.send('hello websockets')
}
ws.onmessage = function(evt){
console.log('Received message:'+evt.data)
ws.close()
}
ws.onclose = function (evt){
console.log('connection closed.')
}

  5.CORS方法

//CORS【 参考质料】(http://www.ruanyifeng.com/blog/2016/04/cors.html)
//url (必须),options(可选) 
fetch('/some/url',{
//配置属性才能跨域
method:'get
}).then(function(response){ }).catch(function(err){
//出错了,等价于 then 的第二个参数
});

  

最新文章

  1. (转)webHttpBinding、basicHttpBinding和wsHttpBinding区别
  2. iOS一些系统事件的生命周期
  3. docker--wekan安装
  4. 理解Linux中断 (2)【转】
  5. swf2pdf转swf时字符集问题【转】
  6. Linux守护进程daemon
  7. 《ICSharpCode快速解压缩帮助类》——即粘即用
  8. 客户端技术:Cookie 服务端技术:HttpSession
  9. error:stray&amp;#39;\243&amp;#39;in program
  10. css水平垂直居中
  11. Alpha冲刺集合
  12. Unity 5.X扩展编辑器之打包assetbundle
  13. Docker Swarm 配置文件存储
  14. Anaconda常用命令大全
  15. bbs项目中的零碎点记录
  16. 并发编程之 Java 内存模型 + volatile 关键字 + Happen-Before 规则
  17. P1550 [USACO08OCT]打井Watering Hole
  18. 【转】Microsoft .Net Remoting 之.Net Remoting基础篇
  19. VS2013下使用log4cplus
  20. TreeSet基本用法

热门文章

  1. 利用MYSQL的函数实现用户登录功能,进出都是JSON(第一版)
  2. android selector shape 使用
  3. 涂抹mysql笔记-安装mysql
  4. VLAN中继协议
  5. Java中通过Class的反射来获取方法
  6. gitlab Api接口使用
  7. PL2303 USB转串口 com
  8. 规模预算 之 FP法(作成中)
  9. sendmail报错Relaying denied
  10. MySQL 物理文件体系结构的简单整理说明