jsonp跨域

jsonp跨域:
动态创建script,借助script发送跨域请求,服务端返回的js语句,服务器端将要返回的数据,填充进js语句里返回,script收到js语句执行js语句,在ajax中添加dataType:jsonp

	client.html
	//引入jq.js
	$("button").click(function(){
		$ajax({
			url:'http://localhost:3000',
			type:'get',
			dataType:'jsonp',
			success:function(result){
				alert(result)
			}
		})
	})

如果把res.end()放到setTimeout里,可以看到函数的执行过程。

	app.js
	const http=require('http');
	const url=require('url');
	http.createServer(
		(req,res)=>{
			var url=url.parse(req.url,true);
			var callback=url.query.callback;
			var num='12345';
			res.write(`${callback}($"{num}")`)
			res.end();
		}
	).listen(3000);

jsonp是json的一种使用模式,用于解决主流浏览器的跨域数据访问的问题,由于同源策略,一般来说,server1.com的网页无法与不是server1的服务器沟通,而html的script是个例外,可以动态创建script

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值