V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
cwz346852114
V2EX  ›  问与答

iframe 嵌套如何解决页面通信的跨域问题

  •  1
     
  •   cwz346852114 · 2020-05-20 12:58:53 +08:00 · 1499 次点击
    这是一个创建于 1429 天前的主题,其中的信息可能已经有所发展或是发生改变。

    a 页面为父页面 b 页面为子页面

    a 和 b 页面不在同一个一级域名下 无法使用 window.domain

    a 页面通过 iframe 引入 b 页面 b 页面通过 window.parent.fnc() fnc 为 a 页面的方法

    这样会导致跨域 请问大佬们有什么好的解决方案吗

    7 条回复    2020-05-21 13:17:44 +08:00
    tuean
        1
    tuean  
       2020-05-20 13:21:02 +08:00   ❤️ 1
    可以使用 postMessage
    cwz346852114
        2
    cwz346852114  
    OP
       2020-05-20 13:34:03 +08:00
    不同域名下
    cwz346852114
        3
    cwz346852114  
    OP
       2020-05-20 13:34:20 +08:00
    @tuean 不同域名下
    shiji
        4
    shiji  
       2020-05-20 13:43:07 +08:00 via iPhone
    @cwz346852114 一楼说的是正确的。
    前提是你这两个域名都能控制。

    如果其中一个不是你的域名 那就不可能了
    cwz346852114
        5
    cwz346852114  
    OP
       2020-05-20 15:12:12 +08:00
    @shiji 有个域名是外包那边的 外包的页面嵌入我的页面
    gouflv
        6
    gouflv  
       2020-05-20 15:17:41 +08:00 via iPhone   ❤️ 1
    别多想,就是 postMessage
    tuean
        7
    tuean  
       2020-05-21 13:17:44 +08:00
    @cwz346852114 你可以先了解下 postMessage 的使用 简单来说就是在同一浏览器 tab 下跨 iframe 传递参数的一种方式 当然 传递方和接收方两个站你都需要拥有控制权
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   5588 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 02:54 · PVG 10:54 · LAX 19:54 · JFK 22:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.