007:vue实现与iframe实现页面数据通信

首页先搭建一个html页面和vue页面,在vue页面中,嵌入我们需要的iframe页面

文章目录

  • 1. 搭建 html 页面和 vue 页面
  • 2. 实现 `iframe` 向 `vue` 页面通信
  • 3. 在实现 `vue` 向 `iframe` 页面通信

1. 搭建 html 页面和 vue 页面

暂定为 iframeDemo.htmlvueDemo.vue 页面
在这里插入图片描述

  1. 编写 iframeDemo.html 页面(完整代码)
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>html,body {margin: 0;padding: 0;overflow: hidden;}.box {width: 100%;height: 200px;border: 2px solid #000;box-sizing: border-box;}</style>
</head><body><div class="box"><button id="sendBtn">我是iframe页面按钮</button></div>
</body></html><script type="text/javascript">// iframe页面点击发送按钮,传递事件给vuedocument.getElementById("sendBtn").addEventListener("click", () => {window.parent.postMessage({data: {code: "success",test: "我是点击iframe页面按钮后过来的数据"}}, '*');});// 监听vue页面传来的message事件window.addEventListener("message", (event) => {const data = event.dataif (data.code === 'success') {alert(data.test)}}, false);
</script>
  1. 编写 vueDemo.vue 页面(完整代码),嵌入 iframeDemo.html 在实现两个页面的互相数据通信
<template><div class="home"><div class="body"><iframe src="/iframeDemo.html" ref="iframe" frameborder="0" width="100%" height="4  00px" /><el-button @click="btnClick">我是vue页面按钮</el-button></div></div>
</template><script>export default {data() {return {}},methods: {// 给iframe发送事件btnClick() {this.iframeWin.postMessage({code: 'success',test: '我是点击vue页面按钮后过来的数据!',},'*')},},mounted() {// 监听iframe页面点击按钮触发事件window.addEventListener('message', (event) => {const data = event.data.dataif (data.code === 'success') {alert(data.test)}})this.iframeWin = this.$refs.iframe.contentWindow},}
</script><style scoped lang="scss">.home {.body {width: 890px;height: 100%;border: #ff3366 solid 10px;box-sizing: border-box;box-sizing: border-box;padding: 20px;}}
</style>

2. 实现 iframevue 页面通信

  1. 点击iframe页面,通过 window.parent.postMessage 传递数据到vue页面
  2. vue页面,通过 window.addEventListener('message') 去接收iframe传递过来的数据
  1. 实现效果如下(点击iframe页面的按钮事件,在vue页面中监听并弹窗提示)

在这里插入图片描述

  1. iframeDemo.html 中新建按钮的点击事件
<button id="sendBtn">我是iframe页面按钮</button>
<script type="text/javascript">// iframe页面点击发送按钮,传递事件给vuedocument.getElementById("sendBtn").addEventListener("click", ()=> {window.parent.postMessage({data: {code:"success",test:"我是点击iframe页面按钮后过来的数据"}}, '*');});
</script>
  1. vueDemo.vue 页面的 mounted 中监听iframe页面传过来的 message 事件
mounted() {// 监听iframe页面点击按钮触发事件window.addEventListener('message', (event) => {const data = event.data.dataif (data.code === 'success') {alert(data.test)}})
},

3. 在实现 vueiframe 页面通信

  1. 点击vue页面,通过 postMessage 传递数据到iframe页面
  2. iframe页面,通过 window.addEventListener('message') 去接收vue传递过来的数据
  1. 实现效果如下(点击vue页面的按钮事件,在iframe页面中监听并弹窗提示)

在这里插入图片描述

  1. vueDemo.html 中新建按钮的点击事件
<el-button @click="btnClick">我是vue页面按钮</el-button>
methods: {// vue页面点击发送按钮,传递事件给vuebtnClick() {this.iframeWin.postMessage({code: 'success',test: '我是点击vue页面按钮后过来的数据',},'*')},
},
  1. iframeDemo.vue 页面的 mounted 中监听iframe页面传过来的 message 事件
// 监听vue页面传来的message事件
window.addEventListener("message", (event) => {const data = event.dataif (data.code === 'success') {alert(data.test)}
}, false);

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

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

相关文章

python文件操作知识

【一】操作流程&#xff1a; 打开文件&#xff0c;得到一个文件句柄&#xff08;对象&#xff09;&#xff0c;赋给一个对象。通过文件句柄对文件进行操作。关闭文件。 【 二 】 使用方法 open&#xff08;路径 文件名&#xff0c;读写模式&#xff09; 如下&#xff1a; …

MySQL主从复制(一主一从、双主双从)

一、概述 1. 数据库主从概念、优点、用途 主从数据库是什么意思呢&#xff0c;主是主库的意思&#xff0c;从是从库的意思。数据库主库对外提供读写的操作&#xff0c;从库对外提供读的操作。   数据库为什么需要主从架构呢&#xff1f; 高可用&#xff0c;实时灾备&#x…

MQTT框架和使用

目录 MQTT框架 1. MQTT概述 1.1 形象地理解三个角色 1.2 消息的传递 2. 在Windows上体验MQTT 2.1 安装APP 2.2 启动服务器 2.3 使用MQTTX 2.3.1 建立连接 2.3.2 订阅主题 2.3.3 发布主题 2.4 使用mosquitto 2.4.1 发布消息 2.4.2 订阅消息 3. kawaii-mqtt源码分析…

直面多云困境,聊聊F5分布式云的破局之道

在数字化浪潮的大背景下&#xff0c;我们迎来了一个万物上云的时代。Gartner的调查数据显示&#xff0c;81%的公有云用户选择两个或两个以上的云服务供应商。对企业来说&#xff0c;充分利用多云网络可以实现业务的成功转型和增长。然而机遇与挑战并存&#xff0c;本文从多云网…

使用AWS Glue与AWS Kinesis构建的流式ETL作业(二)——数据处理

大纲 2 数据处理2.1 架构2.2 AWS Glue连接和创建2.2.1 创建AWS RedShift连接2.2.2 创建AWS RDS连接&#xff08;以PG为例&#xff09; 2.3 创建AWS Glue Job2.4 编写脚本2.4.1 以AWS RedShift为例2.4.2 以PG为例 2.5 运行脚本 2 数据处理 2.1 架构 2.2 AWS Glue连接和创建 下…

C++基础 -42- STL库之list链表

list链表的格式(需要定义头文件) list<int> data1(4, 100);list<int> data2(4, 500);list链表的合并接口 举例使用合并接口并且验证 data2.merge(data1);list<int>::iterator ccc;for (ccc data2.begin(); ccc ! data2.end(); ccc){cout << *ccc …

算法学习系列(五):N皇后、数独

目录 引言一、N皇后问题代码实现测试 二、数独问题代码实现测试 引言 这个N皇后问题是很典型的一个递归问题&#xff0c;就是还是要掌握&#xff0c;所谓递归其实就是dfs&#xff0c;一层一层深入下去。数独和N皇后的思路是一样的&#xff0c;只不过一些细节不同而已。 一、N…

TFIDF、BM25、编辑距离、倒排索引

TFIDF TF刻画了词语t对某篇文档的重要性&#xff0c;IDF刻画了词语t对整个文档集的重要性

2024年API安全趋势预测

目录 1.API漏洞的渗透性 2.标准框架的局限性 3.防止漏洞 4.不断上升的威胁和战略建议 案例分析 2024年的潜在威胁 驾驭不断演变的API安全格局 在接下来的部分中&#xff0c;我们将更深入地研究这些趋势&#xff0c;探索标准框架在应对这些新出现的威胁方面的局限性…

数据库学习日常案例20231203-Mysql高级 -- 日志管理篇

Mysql高级 -- 日志篇 *日志类型 1.mysql的6类日志&#xff1a; 2.日志的弊端 *慢查询日志(slow query log) *通用查询日志(general query log) 1.作用&#xff1a; 2.问题场景&#xff1a; 3.查看当前状态 &#xff1a; 4.启动日志&#xff1a; 方式1&#xff1a;永久…

云计算在数字营销中的作用是什么?

营销策略和云计算是一个为企业提供多种优势的系统。它使他们能够取得更大的成功&#xff0c;同时提高产量。这样做的原因是&#xff0c;可以从任何位置远程使用云集成工具和应用程序。基本上&#xff0c;该系统增强了存储设备和传播。同时&#xff0c;它减轻了公司 IT 网络的压…

【Kubernetes】可视化UI界面Dashboard

安装和配置k8s可视化UI界面 一、安装Dashboard1.1、上传镜像并解压1.2、安装dashboard组件1.3、修改service1.4、访问dashboard 二、通过Token令牌访问Dashboard2.1、创建clusterrolebinding2.2、获取token2.3、使用token登录 三、通过kubeconfig文件访问Dashboard3.1、创建clu…

21、pytest参数化中标记单独的测试用例

官方实例 # content of test_expectation_xfail import pytestpytest.mark.parametrize("test_input, expected",[("35",8),("24",6),pytest.param("6*9",42,markspytest.mark.xfail)], ) def test_eval(test_input, expected):asser…

基于ssm vue技术的品牌银饰售卖平台源码和论文737

摘 要 本论文主要是针对品牌银饰售卖而开发进行概述&#xff0c;主要包括对研究的背景和研究现状&#xff0c;以及研究目的等的阐述&#xff0c;也对该系统的各种功能要求&#xff0c;对系统结构&#xff0c;数据库的设计等进行讨论。随着科技与技术的发展&#xff0c;利用计…

Qt篇——QChartView实现鼠标滚轮缩放、鼠标拖拽平移、鼠标双击重置缩放平移、曲线点击显示坐标

话不多说。 第一步&#xff1a;自定义QChartView&#xff0c;直接搬 FirtCurveChartView.h #ifndef FITCURVECHARTVIEW_H #define FITCURVECHARTVIEW_H #include <QtCharts>class FitCurveChartView : public QChartView {Q_OBJECTpublic:FitCurveChartView(QWidget *…

MySQL 8.x 自签证书通过keytool和openssl转成JKS文件

一、写在前面 数据库MySQL 8.0 通过自签命令在datadir下生成了所有的证书文件。由于Java的JDK不支持直接加载PEM格式的证书&#xff0c;所以需要将PEM格式证书转换成Java能够直接加载的JKS格式证书。我们需要将根证书ca.pem转换成JKS格式的根证书truststore.jks&#xff0c;将…

把 Windows 11 装进移动硬盘:Windows 11 To Go

本篇文章聊聊如何制作一个可以“说带走就带走”的 Windows 操作系统&#xff0c;将 Windows11 做成能够放在 U 盘或者移动硬盘里的 WinToGo “绿色软件”。 写在前面 在《开源的全能维护 U 盘工具&#xff1a;Ventoy》这篇文章的最后&#xff0c;我提到了一个关键词 “WinToG…

Mybatis XML 配置文件

我们刚开始就有说Mybatis 的开发有两种方式: 1.注释 2.XML 注解和 XML 的方式是可以共存的 我们前面说的都是注释的方式,接下来是XML方式 XML的方式分为三步 : 1.配置数据库(配在 application.yml 里面) 这个跟注释的配置是一样的,username应该都是一样的,password记得写…

6.Eclipse里下载Subclipse插件

方法一&#xff1a;从Eclipse Marketplace里面下载 具体操作&#xff1a;打开Eclipse --> Help --> Eclipse Marketplace --> 在Find中输入subclipse搜索 --> 找到subclipse点击install 方法二&#xff1a;从Install New Software里下载 具体操作&#xff1a;打开…

OSPF浅析

一、预习&#xff1a; 1、优点&#xff1a; 是一种典型的链路状态路由协议&#xff0c;协议号89&#xff0c;把大型网络分隔为多个较小、可管理的单元&#xff1a;Area a.减少LSA泛洪范围&#xff0c;有效地把拓朴变化 控制在区域内&#xff0c;达到网络优化的目的…