Maoyl's blog Maoyl's blog
首页
  • 前端基础

    • HTML
    • CSS
    • CSS动画
    • JavaScript文章
    • stylus
  • 性能优化

    • 《性能优化》笔记
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《JavaScript设计模式》笔记
    • 《TypeScript 从零实现 axios》
    • TypeScript笔记
    • JS设计模式总结笔记
  • 前端框架

    • Vue相关
    • React相关
  • 前端监控

    • 前端监控简介
  • 学习笔记

    • 《Vue》笔记
    • 《React》笔记
    • 小程序学习笔记
  • 后端基础

    • Nodejs
  • 学习笔记

    • 数据结构
  • 技术文档
  • GitHub技巧
  • 博客搭建
  • 网页性能
  • 学习笔记

    • 《Git》学习笔记
    • 《Vim》学习笔记
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

maoyln

日日行,不怕千万里
首页
  • 前端基础

    • HTML
    • CSS
    • CSS动画
    • JavaScript文章
    • stylus
  • 性能优化

    • 《性能优化》笔记
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《JavaScript设计模式》笔记
    • 《TypeScript 从零实现 axios》
    • TypeScript笔记
    • JS设计模式总结笔记
  • 前端框架

    • Vue相关
    • React相关
  • 前端监控

    • 前端监控简介
  • 学习笔记

    • 《Vue》笔记
    • 《React》笔记
    • 小程序学习笔记
  • 后端基础

    • Nodejs
  • 学习笔记

    • 数据结构
  • 技术文档
  • GitHub技巧
  • 博客搭建
  • 网页性能
  • 学习笔记

    • 《Git》学习笔记
    • 《Vim》学习笔记
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • HTML

  • CSS

  • CSS动画

  • GSAP动画学习

  • JavaScript文章

    • MDN知识及拓展

      • new命令原理
      • js全屏模式
      • 公共滚动条样式(继承)
      • 拖拽操作
      • iframe跨域问题
      • 浏览器语言播放
    • 常用工具

    • ECMAScript

    • 三级目录

  • stylus

  • 性能优化

  • 学习笔记

  • 前端
  • JavaScript文章
  • MDN知识及拓展
maoyln
2022-11-01

iframe跨域问题

# iframe跨域问题

成功解决Blocked a frame with origin "http://127.0.0.1:8080" from accessing a cross-origin frame.

解决方法:

假如当前的项目的域名端口是 http://192.168.0.1:8080,通过页面的 iframe访问 http://127.0.0.1:8080,并接收 http://127.0.0.1:8080/file_system/传过来的消息。

<iframe width="100%" height="100%" frameborder="0" src="http://127.0.0.1:8080/file_system/"></iframe>
1

如果这是直接在子页面上调用 parent.document.getElementById("parentUrl").value=''给父页面传值或者使用 top.location.pathname,就遇到上面跨域问题。

解决方法就是:

在父页面添加监听器,接收子页面的值:

window.addEventListener('message',function(e){
  alert(e.data);
},false);
1
2
3

在子页面在要传值的地方调用以下语句传值:

window.parent.postMessage('值','http://192.168.0.1:8080');
1

如果是非必需的功能,可以用 try {}catch(){}去捕捉问题,避免页面崩溃

编辑 (opens new window)
上次更新: 2025/04/18, 01:42:12
拖拽操作
浏览器语言播放

← 拖拽操作 浏览器语言播放→

最近更新
01
GSAP动画库——如何高效写动画
04-17
02
自适应方案PxToRem
09-10
03
性能优化-requestAnimationFrame
08-10
更多文章>
Theme by Vdoing | Copyright © 2019-2025 备案号:京ICP备19058102号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式