几种跨域的解决方式
2017-07-18 本文已影响0人
柚丶稚橙熟时
jsonp
http://js.jirengu.com/cenuxecevi/2/edit
CORS
http://js.jirengu.com/lateqotuno/1/edit
降域
data:image/s3,"s3://crabby-images/70272/70272b7f1e165cba376b7672b967aa2425ec02f7" alt=""
data:image/s3,"s3://crabby-images/ae2ac/ae2ac5f785be6c9d4ea0cc378cce7fcd4e0aa651" alt=""
a和b的域名不同,因此不能互相操纵DOM
data:image/s3,"s3://crabby-images/93180/93180b798114e2e5cbe494d268e2222a96036441" alt=""
通过降域设置后:
data:image/s3,"s3://crabby-images/35325/3532528e66631878c129d04aa376010bd80986f1" alt=""
便可以跨域操纵了:
data:image/s3,"s3://crabby-images/72781/72781d9884dc6cc8c6fc9104838908f4a26b3bd9" alt=""
postMessage
窗口a
<script>
var aa = document.getElementById("a");
aa.addEventListener("input",function(){
window.frames[0].postMessage(this.value,"*");
console.log(12);
})
</script>
窗口b
<script>
var bb = document.getElementById("b");
window.addEventListener("message",function(e){
console.log(3333);
bb.value=e.data;
})
</script>
data:image/s3,"s3://crabby-images/f2462/f2462dae6d2aca716a98360df41a3063ca739ffc" alt=""