自己封装的 Jsonp 函数

本文深入探讨了JSONP跨域请求的实现原理,详细解释了如何通过动态创建script标签来发送请求,并将回调函数挂载到全局作用域中,以实现跨域数据的获取。此外,还介绍了如何确保每次请求的函数名唯一,以及如何处理接收到的响应数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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);
}

  

转载于:https://www.cnblogs.com/llxin/p/6209595.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值