跨域通信方式

1、jsonp:通过script,这里不详细说了

2、hash:就是url#号后面的东西,hash的改变不会刷新页面(search就URL?号后面的东西,search的改变会刷新页面,不可以用来跨域通信)例子如下:

A页面通过iframe或frame嵌入了跨域的页面B

    //A页面
    var b = document.getElementsByClassName('left')
    b.src = b.src + '#data'
    //B页面
    window.onhashchange = function (ev) { 
        var hash = window.location.hash;
    }

3、postMessage

窗口A(http://w.com)像跨域的窗口B(http://b.com)发送信息
    //A页面
    window.postMessage('data', 'http://b.com')
    //B页面
    window.addEventListener('message', function (ev) { 
        console.log(ev.origin) //http://w.com
        console.log(ev.source) //Awindow
        console.log(ev.data)//data
    })

4、websocket

    var sc = new WebSocket('wss://echo.websocket.org')
    sc.open = function (ev) {
        ws.send('hello ws')
    }
    sc.message = function (ev) {
        console.log(ev.data)
    }
    sc.close = function (code) { 
        console.log('connect closed')
    }

5、cors:就是浏览器会拦截ajax请求,如果发现发送了跨域请求,就会在http请求头中加一个origin

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值