自己封装的 Jsonp 函数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自己封装的 Jsonp 函数相关的知识,希望对你有一定的参考价值。

function jsonp(url,data,callback,succ,fn){
	var oS = document.createElement(‘script‘);
	var head = document.getElementsByTagName(‘head‘)[0];
	
	/*
		保证每一次请求数据的接收函数名不重复 
	*/
	var fnName = ‘jquery_‘+new Date().getTime()+Math.random();
	//因为函数名不能有.所以把.替换成空
	fnName = fn || fnName.replace(‘.‘,‘‘);
	
	var arr = [];
	for(var attr in data){
		arr.push(attr+‘=‘+data[attr]);
	}
	data = arr.join(‘&‘);
	
	
	//把接收函数挂在全局,要做fn不能是死,如果有固定的就走固定的,如果没有固定的那么随机
	window[fnName] = function(json){
//		console.log(json)
		head.removeChild(oS);
		succ && succ(json);
	}
	oS.src = url + ‘?‘ + data + ‘&‘+callback+‘=‘+fnName;
	head.appendChild(oS);
}

  

以上是关于自己封装的 Jsonp 函数的主要内容,如果未能解决你的问题,请参考以下文章

同源与跨域JSONP(函数封装)CORS

原生的js实现jsonp的跨域封装

封装JSONP

封装一个JSONP请求

原生JS简单封装JSONP跨域获取数据

jsonp封装