iframe内的通信(桥接方法),使用postMessage和使用自定义事件

news2025/1/12 21:10:15

1、首先看一下我的文档目录
在这里插入图片描述

2、 接下来,上代码

outer.html

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>外部</title>

  <style>
    .outer-wrap {
      display: flex;
      width: 500px;
      height: 500px;
      border: 1px solid;
      margin: auto;
    }

    .outer {
      margin: auto;
    }
  </style>
</head>

<body>
  <div class="outer-wrap">
    <div class="outer">
      外部
      <iframe id="inlineFrameExample" title="Inline Frame Example" width="300" height="200"
        src="http://127.0.0.1:5500/iframe/inner.html">
      </iframe>
    </div>
  </div>

  <script>
    // 使用postMessage
    window.addEventListener('message', (event) => {
      console.log('Received message is:使用postMessage', event.data);
    }, false);

    // 使用事件
    window.trigger = () => {
      console.log('使用事件')
    }
  </script>
</body>
</html>

inner.html

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>内部</title>

  <style>
    html,body{
      height: 90%;
    }

    .inner-wrap {
      height: 100%;
      display: flex;
      margin: auto;
    }

    .inner {
      width: 100px;
      height: 100px;
      margin: auto;
      text-align: center;
    }
  </style>
</head>

<body>
  <div class="inner-wrap">
    <div class="inner">
      <button type='button' id="test" onclick="doSomeThing()">内部点击-使用postMessage</button>
      <button type='button' id="test" onclick="doSomeThingOther()">内部点击-使用事件</button>
    </div>
  </div>

  <script>
    // 使用postMessage
    const doSomeThing = () => {
      const data = {
        isDJ: true,
        isHoliday: false,
      }
      window.parent.postMessage(data, "*");
    }

    // 使用事件
    const doSomeThingOther = () => {
      window.parent.window.trigger();
    }

  </script>
</body>
</html>

补充:
这里的http://127.0.0.1:5500/iframe/inner.html是使用 vscode 插件 Open With Live Server启动的

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1048069.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[C++随笔录] stack queue使用

stack && queue使用 stackqueue题目训练 stack 栈的特点是 先进后出(first in last out) 我们可以看出, stack的接口相比 vector/string/list 的接口少的太多了 构造函数 && 容器适配器 容器适配器的含义: 首先, 适配器 — — 用户传数据进来, 我们用合适的…

MMDet初尝试:以官方文档为例,训练模型

使用前配置 按照官方文档配置环境&#xff1a;https://mmdetection.readthedocs.io/zh_CN/3.x/get_started.html 安装conda/Miniconda 创建并激活一个 conda 环境 conda create --name openmmlab python3.8 -y conda activate openmmlab安装PyTorch&#xff08;GPU平台&#…

C++ 多态:(使用Shape类层次结构的多态性的屏幕管理器)开发一个基本图形软件包

基于上篇C 多态&#xff1a;Shape类层次结构https://mp.csdn.net/mp_blog/creation/editor/133175074 【问题描述】 使用C 多态&#xff1a;Shape类层次结构中实现的Shape类层次。仅限于二维形状&#xff0c;如正方形&#xff0c;长方形、三角形和圆。和用户进行交互&#xff…

计算机操作系统 (王道考研)笔记(三)文件

目录 1 文件1.1 内存映射文件1.1.1 定义1.1.2 传统文件访问方式1.1.3 内存映射文件访问方式 1.2 文件管理1.3 文件的逻辑结构1.4 文件目录1.5 文件物理结构&#xff08;文件分配方式&#xff09;1.6文件的逻辑结构和物理结构 2 I/O3 缓冲区&#xff0c;磁盘 1 文件 1.1 内存映…

第二证券:北证50是什么意思?

随着中国资本市场的不断发展&#xff0c;投资者开始关注市场指数。北证50指数是其中一个备受关注的指数。那么&#xff0c;北证50究竟是什么意思呢&#xff1f;本文将从定义、历史、构成股票等多个角度分析北证50指数&#xff0c;帮助读者全面了解该指数。 1.定义 北证50指数…

基于Web安全的Python编程(1)

目录 一、http协议基础知识介绍 1、http协议分类 2、请求方法 3、什么是URL 4、请求头 5、响应状态码 二、常用Python库、函数、操作 三、http常用请求方法 1、不带参请求 2、带参数请求&#xff08;get和post存在细微区别&#xff09; 四、http响应属性获取 1、获取…

TikTok营销成功秘籍:ROI指标的黄金法则

在当今数字营销领域&#xff0c;TikTok已经崭露头角&#xff0c;成为了品牌和营销者们争相追逐的热门平台。 然而&#xff0c;要在TikTok上取得成功&#xff0c;不仅需要创意和内容&#xff0c;还需要精确的ROI&#xff08;投资回报率&#xff09;指标来衡量和优化你的营销策略…

【python入门篇】列表简介及操作(2)

列表是什么&#xff1f; 列表是由一系列按特定顺序排列的元素组成。你可以创建包含字母表中的所有字母、数字 0~9 或所有家庭成员的列表&#xff1b;也可以将任何东西加入列表中&#xff0c;其中的元素之间可以没有任何关系。列表通常包含多个元素&#xff0c;因此给列表指定一…

图片转RGB数组格式

0 Preface/Foreword 嵌入式开发中&#xff0c;想要在LCD屏幕中显示任意照片&#xff0c;该如何操作&#xff1f; 根据LCD的大小确定把照片进行缩放&#xff1b;比如LCD的规格为&#xff1a;360 RGB* 360&#xff0c; 原始照片的大小为&#xff1a;1000RGB*1000&#xff0c;那…

FlashAttention2原理解析以及面向AIGC的加速实践

FlashAttention-2提出后&#xff0c;便得到了大量关注。本文将具体讲述FlashAttention-2的前世今生&#xff0c;包括FlashAttention1&2的原理解析、加速效果比较以及面向AIGC的加速实践&#xff0c;在这里将相关内容与大家分享&#xff5e; 引言 将 Transformers 扩展到更长…

文心一言 VS 讯飞星火 VS chatgpt (102)-- 算法导论9.3 8题

八、用go语言&#xff0c;设 X[1…n]和 Y[1…n]为两个数组&#xff0c;每个都包含n个有序的元素。请设计一个 O(lgn)时间的算法来找出数组 X和Y中所有 2n 个元素的中位数。 文心一言&#xff1a; 要在 O(lgn) 时间内找出两个有序数组 X 和 Y 中所有元素的中位数&#xff0c;可…

vue最新前端面试题系列(1-5)

前言: 欢迎浏览和关注本专栏《 前端就业宝典 》, 不管是扭螺丝还是造火箭, 多学点知识总没错。 这个专栏是扭螺丝之上要造火箭级别的知识,会给前端工作学习的小伙伴带来意想不到的帮助。 文章目录 1,Vue 常用的修饰符都有哪些?事件修饰符表单修饰符2,$route和 $router的…

企业年报API的应用:从金融投资到市场研究

引言 在数字化时代&#xff0c;企业年报不再仅仅是一份财务报告&#xff0c;它们变成了宝贵的信息资源&#xff0c;可用于各种商业应用。企业年报API已经改变了金融投资和市场研究的方式&#xff0c;使得从中获取数据变得更加高效和灵活。本文将深入探讨企业年报API的应用&…

创建线程的4种方法

目录 一.前言 1.关于进程调度 (1)为什么要调度? (2)调度的真正对象 (3)调度的资源 2.线程 (1).线程的写法 (2)线程创建的方法 1.继承Thread (1)使用继承Thread,重写run的方式来创建线程 (2)继承Thread,使用匿名内部类 2.实现Runnable (1)使用实现Runnable,重写run…

基于SSM的网上药品售卖系统设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#x…

衷心 祝愿

达之云衷心祝愿您&#xff0c;中秋国庆双节快乐&#xff0c;阖家幸福&#xff01;感谢您们一直以来对达之云的关注与支持。 双节来临之际&#xff0c;达之云发布全新产品——达之云CDP客户数据平台&#xff08;Dazdata CDP&#xff09;&#xff0c;致力于为中小企业提供互联网营…

【VUE复习·6】监视属性watch:用途、两种写法、简写、应用时注意事项(重点)、深度监视(重点)

总览 1.监视属性是用来干什么的&#xff1f; 2.监视属性的两种写法 3.应用时注意事项 4.深度监视 一、监视属性是用来干什么的&#xff1f; 1.用途 监视一个值&#xff08;可以是基本属性 data&#xff0c;或者是计算属性 computed&#xff09;是否被改变。如果此值被改变&…

品牌奖项+个人奖项双丰收,极智嘉全面展现自身硬核实力

最近&#xff0c;中国物流与采购联合会发布了2022年度科学技术奖获奖名单。在这份名单中&#xff0c;极智嘉与国药物流、南京医药、九州通医药以及多所高校合作&#xff0c;成功研发并应用了“面向医药流通的大规模机器人集群系统关键技术”。这项研究赢得了科学技术进步奖的一…

SpringCloud + SpringGateway 解决Get请求传参为特殊字符导致400无法通过网关转发的问题

title: “SpringCloud SpringGateway 解决Get请求传参为特殊字符导致400无法通过网关转发的问题” createTime: 2021-11-24T10:27:5708:00 updateTime: 2021-11-24T10:27:5708:00 draft: false author: “Atomicyo” tags: [“tomcat”] categories: [“java”] description: …

Win10检测和配置使用千兆网

注&#xff1a;一般只有比较旧的电脑才会是百兆网卡&#xff08;我的2019年笔记本dell灵越是百兆网卡瑞昱RTL810x/8139&#xff0c;离谱&#xff09;。 查看硬件是否为千兆网卡 cmd内执行如下&#xff08;100000000b100000kb100Mb&#xff0c;我这里显示的为百兆&#xff09;…