vue與iframe之間的交互方式(一看就會(huì))
vue與iframe之間的交互
首先介紹一下使用背景,前端采用html單頁(yè)面引用vue的方式(逼不得已這么做,否則直接用vue不香嘛),廢話不多說(shuō)
頁(yè)面大致是這樣,現(xiàn)在需要做的是在iframe頁(yè)面里面觸發(fā)事件跳轉(zhuǎn)頁(yè)面,并且使父級(jí)vue頁(yè)面的左側(cè)菜單選中相應(yīng)頁(yè)面的菜單,當(dāng)然iframe子頁(yè)面也是vue,但是其他頁(yè)面也不影響
子頁(yè)面向父頁(yè)面?zhèn)髦?/h3>
1.在iframe頁(yè)面里觸發(fā)事件,找到他的父級(jí)頁(yè)面的dom元素,用postMessage傳值,里面所有的都是參數(shù),cmd是為了能在父級(jí)vue頁(yè)面區(qū)分該操作的用途
2.在父級(jí)vue頁(yè)面的周期函數(shù)mounted中監(jiān)聽(tīng)iframe中發(fā)來(lái)的消息,傳來(lái)的參數(shù)就在event.data里面。(loadHtmlFrag()則是在父級(jí)vue頁(yè)面methods中的方法)
父頁(yè)面向子頁(yè)面?zhèn)髦?/h3>
會(huì)了子頁(yè)面向父業(yè)面?zhèn)髦?,那父?yè)面向子頁(yè)面?zhèn)髦狄簿蜁?huì)了,就是吧一二步驟調(diào)換未知
1.在父頁(yè)面中觸發(fā)事件傳遞參數(shù),在父頁(yè)面通過(guò)ref來(lái)得到iframe子頁(yè)面的dom元素,然手使用postMessage傳參。
另:通過(guò)ref獲取dom,父頁(yè)面的iframe標(biāo)簽里寫(xiě)ref就行
2.和上面一樣,在子頁(yè)面的周期函數(shù)mounted中監(jiān)聽(tīng)父頁(yè)面發(fā)來(lái)的消息
vue與html之間iframe交互
1.父級(jí)調(diào)用子級(jí)ifram中的方法
document.getElementById(“id”).contentWindow.func()
id為iframe的id,func為引入iframe中的方法
2.子級(jí)iframe(html 或者vue)調(diào)用父級(jí)html中的方法
window.parent.func()
func為父級(jí)html的方法
3.vue中調(diào)用子級(jí)iframe html 中的方法
this.$refs.iframe.contentWindow.func()
4.在iframe中調(diào)用vue中的方法
先把vue中的方法暴露到window對(duì)象上
created(){ let _this = this ? ? ? ? window.funcname = ()=>{ ? ? ? ? //vue中的方法 ? ? ? ? ? ? ? _this.func() ? ? ? ? ? ? ? } ? ? } ? ?
在iframe中調(diào)用
window.parent.funcname()
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
源碼分析Vue.js的監(jiān)聽(tīng)實(shí)現(xiàn)教程
這篇文章主要通過(guò)源碼分析介紹了Vue.js的監(jiān)聽(tīng)實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),相信對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-04-04Vue實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建和刪除數(shù)據(jù)的方法
下面小編就為大家分享一篇Vue實(shí)現(xiàn)動(dòng)態(tài)創(chuàng)建和刪除數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03vue 中常見(jiàn)的時(shí)間格式轉(zhuǎn)換
這篇文章主要介紹了vue 中常見(jiàn)的時(shí)間格式轉(zhuǎn)換,需要的朋友可以參考下2022-05-05vue2+tracking實(shí)現(xiàn)PC端的人臉識(shí)別示例
本文主要介紹了vue2+tracking實(shí)現(xiàn)PC端的人臉識(shí)別示例,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05全局安裝 Vue cli3 和 繼續(xù)使用 Vue-cli2.x操作
這篇文章主要介紹了全局安裝 Vue cli3 和 繼續(xù)使用 Vue-cli2.x操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09vue3+elementPlus?table中添加輸入框并提交校驗(yàn)
這篇文章主要介紹了vue3+elementPlus?table里添加輸入框并提交校驗(yàn),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-08-08Vue使用正則校驗(yàn)文本框?yàn)檎麛?shù)
這篇文章主要介紹了Vue使用正則校驗(yàn)文本框?yàn)檎麛?shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10vue使用recorder.js實(shí)現(xiàn)錄音功能
這篇文章主要為大家詳細(xì)介紹了vue使用recorder.js實(shí)現(xiàn)錄音功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11