大佬教程收集整理的这篇文章主要介绍了浅谈 JSONP,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
URL | 说明 | 是否允许通信 |
---|---|---|
http://www.a.com/a.js – http://www.a.com/b.js | @H_450_17@同一域名下允许 | |
http://www.a.com/a.js – http://www.a.com/script/b.js | @H_450_17@同一域名下不同文件夹允许 | |
http://www.a.com:8000/a.js – http://www.a.com/b.js | @H_450_17@同一域名下不同端口不允许 | |
http://www.a.com:8000/a.js – http://www.a.com/b.js | @H_450_17@同一域名下不同端口不允许 | |
http://www.a.com/a.js – http://172.16.7.93/b.js | @H_450_17@域名和域名对应的IP不允许 | |
http://www.a.com/a.js – https://www.a.com/b.js | @H_450_17@同一域名下不同协议不允许 | |
http://www.a.com/a.js – https://script.a.com/b.js | @H_450_17@主域相同、子域不同不允许 | |
http://www.a.com/a.js – https://www.b.com/b.js | @H_450_17@不同域名不允许 |
特别注意亮点:
+ 在跨域问题上,域仅仅是通过 “URL首部”来识别而不会去尝试判断相同 IP 地址对应两个域或两个域是同一个IP
$('#redBtn').click(function() {
$.get("http://localhost:8081/js/jquery-3.1.1.min.js",function(data) {
console.log(data)
})
});
JSONP 要解决的就是这个问题。
<script type=@H_301_143@"text/javascript" src=@H_301_143@"http://localhost:8081/js/jquery-3.1.1.min.js"></script>
200,请求成功。8080端口向8081端口请求资源,通过 src 请求成功,这就是 JSONP 的基础。
jsonpcallBACk({"Email":"issacyoung@msn.cn","Name":"Issac Young"})
从 8080 端口访问 8081 的 JSON 文件,约定俗成的再 QueryString 后加上 callBACk 参数。
<script type=@H_301_143@"text/javascript"> function jsonpcallBACk(data){ console.log(data) } function CreateScript(srC) { $("<script><//script>").attr("src",srC).appendTo("body") } $('#redBtn').click(function() { CreateScript("http://localhost:8081/jsondata.json?callBACk=jsonpcallBACk"); }); </script>
输出成功!
上面的方式略显繁琐,庆幸的是 jQuery 已经帮我们做好的封装。
function jsonpcallBACk(data) {
console.log(data)
}
$('#redBtn').click(function() {
$.ajax({
url: 'http://localhost:8081/jsondata.json',dataType: "jsonp",jsonp: "callBACk",success: function(data) {
console.log(data)
}
})
});
输出成功。
以上是大佬教程为你收集整理的浅谈 JSONP全部内容,希望文章能够帮你解决浅谈 JSONP所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。