位置: IT常识 - 正文

vue内嵌iframe跨域通信(vue页面嵌套iframe vue页面)

编辑:rootadmin
vue内嵌iframe跨域通信

推荐整理分享vue内嵌iframe跨域通信(vue页面嵌套iframe vue页面),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue iframe 跨域,vue页面嵌套iframe vue页面,vuex iframe,vue如何加跨域处理,vue页面嵌套iframe vue页面,vue使用iframe跳转别的页面,vue 嵌入iframe,vue页面嵌套iframe vue页面,内容如对您有帮助,希望把文章链接给更多的朋友!

1、Vue组件中如何引入iframe?

2、vue如何获取iframe对象以及iframe内的window对象?

3、vue如何向iframe内传送信息?

4、iframe内如何向外部vue发送信息?

一、Vue组件中如何引入iframe?

直接通过添加iframe标签,src属性绑定data中的src,第一步引入就完成了

<template> <div class="act-form"> <iframe :src="src"></iframe> </div></template><script>export default { data () { return { src: '你的src' } }}</script>vue内嵌iframe跨域通信(vue页面嵌套iframe vue页面)

二、vue如何获取iframe对象以及iframe内的window对象?

获取iframe的window对象,因为只有拿到这个对象才能向iframe中传值

<template> <div class="act-form"> <iframe :src="src" ref="iframe"></iframe> </div></template><script>export default { data () { return { src: '你的src' } }, mounted () { // 这里就拿到了iframe的对象 console.log(this.$refs.iframe) // 这里就拿到了iframe的window对象 console.log(this.$refs.iframe.contentWindow) }}</script>

三、vue如何向iframe内传送信息?

通过postMessage,具体关于postMessage是什么,自己去google,   我的理解postMessage是有点类似于UDP协议,就像短信,是异步的,你发信息过去,但是没有返回值的,只能内部处理完成以后再通过postMessage向外部发送一个消息,外部监听message   为了让postMessage像TCP,为了体验像同步的和实现多通信互不干扰,特别制定的message结构如下

{ cmd: '命令', params: { '键1': '值1', '键2': '值2' }}

 通过cmd来区别这条message的目的

具体代码如下

<template> <div class="act-form"> <iframe :src="src" ref="iframe"></iframe> <div @click="sendMessage">向iframe发送信息</div> </div></template><script>export default { data () { return { src: '你的src', iframeWin: {} } }, methods: { sendMessage () { // 外部vue向iframe内部传数据 this.iframeWin.postMessage({ cmd: 'getFormJson', params: {} }, '*') }, }, mounted () { // 在外部vue的window上添加postMessage的监听,并且绑定处理函数handleMessage window.addEventListener('message', this.handleMessage) this.iframeWin = this.$refs.iframe.contentWindow }, handleMessage (event) { // 根据上面制定的结构来解析iframe内部发回来的数据 const data = event.data switch (data.cmd) { case 'returnFormJson': // 业务逻辑 break case 'returnHeight': // 业务逻辑 break } }}</script>

四、iframe内如何向外部vue发送信息?

现在通过单击‘向iframe发送信息’这个按钮,从外部vue中已经向iframe中发送了一条信息

{ cmd: 'getFormJson', params: {}}

那么iframe内部如何处理这个信息?

<!DOCTYPE html><html lang="en"><head> <meta charset="utf-8"> <title>iframe Window</title> <style> body { background-color: #D53C2F; color: white; } </style></head><body> <h1>Hello there, i'm an iframe</h1> <script> // 向父vue页面发送信息 window.parent.postMessage({ cmd: 'returnHeight', params: { success: true, data: document.body.scrollHeight + 'px' } }, '*'); // 接受父页面发来的信息 window.addEventListener("message", function(event){ var data = event.data; switch (data.cmd) { case 'getFormJson': // 处理业务逻辑 break; } }); </script></body></html>

至此为止,内部的收发信息和外部的收发信息都已解决!

下面是完整代码:

<template> <div class="act-form"> <div class="nav"> <img src="https://www.yuucn.com/wp-content/uploads/2023/04/1682042997-37fa8c727f1f06d.png" @click="back()"> <div class="title">报名</div> </div> <div class="iframe-out"> <iframe :src="src" ref="iframe" @load="iframeLoad"></iframe> </div> <div v-if="isLoaded" class="send-form"><div class="send" @click="sendMessage()">提交</div></div> </div></template><!-- Add "scoped" attribute to limit CSS to this component only --><style lang="sass" rel="stylesheet/sass"> @import "style.scss";</style><script>import { Toast, Indicator } from 'mint-ui'import api from '@/utils/api'export default { data () { return { src: '', iframeWin: null, isLoaded: false } }, created () { let matchFamily = this.$store.state.matchFamily this.src = process.env.BASE_URL + '/matches/' + matchFamily.match.id + '/act/' + matchFamily.act.id + '/joinweb?token=' + this.$store.state.token }, mounted () { window.addEventListener('message', this.handleMessage) this.iframeWin = this.$refs.iframe.contentWindow // 开启加载动画 Indicator.open({ text: '努力加载中...', spinnerType: 'triple-bounce' }) }, methods: { back () { this.$router.push('/actIntro') }, sendMessage () { this.iframeWin.postMessage({ cmd: 'getFormJson', params: {} }, '*') }, iframeLoad () { // 关闭加载动画 Indicator.close() }, async handleMessage (event) { const data = event.data switch (data.cmd) { case 'returnFormJson': if (data.params.success) { // 调用报名方法 await this.enroll(data.params.data) } else { console.log('returnFormJson失败') console.log(data.params) } break case 'returnHeight': if (data.params.success) { this.$refs.iframe.height = data.params.data this.isLoaded = true } break } }, async enroll (data) { let matchFamily = this.$store.state.matchFamily let result = await api.enroll(matchFamily.match.id, matchFamily.act.id, data) if (result.success) { if (result.data.status === 'no_pay') { // 更新缓存 let resultMatch = await api.match(matchFamily.match.id, {}) if (resultMatch.success) { this.$store.commit('SET_CURRENT_MATCH', resultMatch.data) } Toast({ message: '报名成功', position: 'bottom' }) this.$router.push('/match/' + matchFamily.match.id + '/mdetail') } else { console.log('需要跳转到支付页面') } } } }}</script>
本文链接地址:https://www.jiuchutong.com/zhishi/297404.html 转载请保留说明!

上一篇:js查找数组中符合条件的元素(js查找数组所有符合条件数据)

下一篇:【蓝桥杯真题】当蓝桥杯开设Web组之后,对几题能拿省一?(蓝桥杯真题c语言)

  • 初次购买金税盘一般多少钱
  • 长期借款到期一年怎么算
  • 一张发票能分开做帐务处理吗
  • 餐饮业申请发票
  • 开票地址太长显示不全
  • 个体工商户开普票流程
  • 展板制作费属于什么服务
  • 餐饮个体工商户交税标准
  • 结存材料应分摊什么
  • 定额材料损耗率国家标准
  • 12月份费用可以计提吗
  • 给个人的返利如何交税
  • 增值税抵扣凭证包括农产品收购发票
  • 稳岗补贴需要交个税吗
  • 出口退税可以用电子专用发票吗
  • 收到投资款需要什么原始凭证
  • 总资产减少率怎么算
  • 小规模税务30万免税政策
  • 旅行社代订住宿发票能报销吗
  • 进项票入账但是不抵扣怎么做账
  • 债券借贷业务属于表外业务吗
  • 个税7月申报7月怎么填
  • 汇算清缴相关分录有哪些
  • 公允价值变动损益在利润表哪里
  • 更换营业执照要多久才能拿到
  • 汇算清缴专项附加扣除去年忘记填的能补填吗?
  • osx无法安装怎么办
  • 微软预购
  • php数组函数大全
  • 汽车消费税有发票吗
  • 计提增值税可以无付凭证吗
  • 营改增后企业要交哪些税
  • 差旅费报销会计凭证
  • 营业外收入账户性质
  • 企业所得税的税收筹划
  • pytorch训练yolov3
  • 火遍全网的超燃神曲旋律震撼人心,听完热血沸腾!
  • 30多岁应该怎么说
  • thinkphp如何连接数据库
  • php的难点
  • 如何办理出口退税备案
  • 文化事业建设费税收优惠政策2023
  • 收到进项发票怎么入账
  • 合伙律师事务所管理办法最新
  • mysql主从复制实现原理
  • 制造费用科目一定无余额
  • 发票开具与小票的关系是怎样的?
  • 外地预缴税款如何查询
  • 稳岗补贴操作流程
  • 海关进口增值税专用缴款书在哪里打印
  • 工地上报销项目有哪些
  • 长期未用的定金可以退吗
  • 跨年的管理费用怎么处理
  • 企业筹建期的开办费后期怎么算
  • 印花税减免额不能为零怎么填
  • 销项税小于进项税怎么结转
  • 个人购汇需要申报吗
  • 计提资产减值是好事还是坏事
  • vista windows
  • 无法使用ie浏览器
  • 图形工具的作用
  • 用指定用户名访问网络
  • bd是什么文件
  • 一岁的宝宝可以喝枸杞水吗
  • linux挂载文件步骤
  • 如何优化资本结构
  • perl fileparse
  • python中matplotlib绘制曲线
  • java线程池创建
  • unity shader lerp
  • javascript基础编程
  • boostrapping
  • 详解jQuery中的empty、remove和detach
  • js 堆排序
  • jQuery中text() val()和html()的区别实例详解
  • 广州出租车发票号码在哪里
  • 进项转出怎么做
  • 购买方销售方什么意思
  • 外省车险保单,有何不利的事
  • 个体税务登记资料不齐怎么办
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设