当我们需要在vue中使用其他模块或者其他地方的一些html页面功能时,我们可以使用iframe去引用html页面,实现他们的交互
首先我们可以再vue页面中使用标签引用html页面
<template> <div> <iframe name="iframeMap" id="iframeMapViewComponent" width="100%" height="470px" v-bind:src="/UploadFiles/2021-04-02/smgHtmlPath">其中src就是我们html的地址,我们可以在data中定义smgHtmlPath属性,在我们的created方法中初始化,为该属性赋予初始值
如果页面加载出来了,我们就可以开始vue页面和html页面的交互了
如果我们需要vue页面调用html页面方法,我们可以使用如下代码
mounted() { this.iframeWin = this.$refs.iframeDom.contentWindow; },首先在我们的mounted方法中得到iframe对象
在vue页面使用postMessage的API向html页面发送请求数据,因为我们的vue和html页面可能不在同一域名,所以会产生跨域的问题,这里我们使用的postMessage可以实现跨域,我这里在google和IE11测试都是可以跨域的
loadSmgxmlModels(data) { this.iframeWin.postMessage(data,"*") }这里的data就是我们要传递给html页面的数据
“*”,这里代表的是所有地址可以接收到,我们也可以指定地址,例如:www.baidu.com
在html页面的标签中编写监听方法,用来监听我们的请求,获取数据
window.addEventListener('message', function(ev) { // 当我们是父子窗口进行消息传递时,可以使用此判断,只接受父窗口传递来的消息, if (ev.source !== window.parent) return; var data = ev.data; console.log("vue传递的数据为:"+data); //下面可以调用我们html页面js中的方法,使用传递的数据进行操作了 }, false);这里我们监听的就是message,可以获取数据。
补充知识:Vue界面使用iframe嵌套html界面的传值问题
一.从父页面给子页面传值
可以通过url进行传值,若嵌入外网例如www.baidu.com,可以设置为
<iframe name = "child" id = "child" :src="/UploadFiles/2021-04-02/www.baidu.com#asd=1">
asd后面跟的值可以根据需要更改,不影响地址的访问
若为本地html文件,类似的可以写作
:src="/UploadFiles/2021-04-02/test.html#asd =1">
但是如何在子页面读取asd的值这个还没探究成功,稍后若寻找到合适的方法会再更新。这种方法比较适合比较简单的需求
二.父页面获取子页面的值
例如我们在子页面设置四个click事件,JS代码如下
<script> var n = 0; function FN() { n = 1; alert('hello1'+n); } function EN() { n = 2; alert('hello1'+n); } function ER() { n = 3; alert('hello1'+n); } function GN() { n = 4; alert('hello1'+n); } </script>那么在父页面我们可以在method中定义如下函数获取到n的值
callchild(){ let obj1=window.frames["child"];//获得对应iframe的window对象 alert(obj1.n); },将callchild函数由某个button触发,可以看到弹出窗口
以上这篇Vue 使用iframe引用html页面实现vue和html页面方法的调用操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]