vue與iframe之間的交互方式(一看就會)
vue與iframe之間的交互
首先介紹一下使用背景,前端采用html單頁面引用vue的方式(逼不得已這么做,否則直接用vue不香嘛),廢話不多說

頁面大致是這樣,現(xiàn)在需要做的是在iframe頁面里面觸發(fā)事件跳轉(zhuǎn)頁面,并且使父級vue頁面的左側(cè)菜單選中相應(yīng)頁面的菜單,當(dāng)然iframe子頁面也是vue,但是其他頁面也不影響
子頁面向父頁面?zhèn)髦?/h3>
1.在iframe頁面里觸發(fā)事件,找到他的父級頁面的dom元素,用postMessage傳值,里面所有的都是參數(shù),cmd是為了能在父級vue頁面區(qū)分該操作的用途

2.在父級vue頁面的周期函數(shù)mounted中監(jiān)聽iframe中發(fā)來的消息,傳來的參數(shù)就在event.data里面。(loadHtmlFrag()則是在父級vue頁面methods中的方法)

父頁面向子頁面?zhèn)髦?/h3>
會了子頁面向父業(yè)面?zhèn)髦担歉疙撁嫦蜃禹撁鎮(zhèn)髦狄簿蜁?,就是吧一二步驟調(diào)換未知
1.在父頁面中觸發(fā)事件傳遞參數(shù),在父頁面通過ref來得到iframe子頁面的dom元素,然手使用postMessage傳參。

另:通過ref獲取dom,父頁面的iframe標(biāo)簽里寫ref就行
![]()
2.和上面一樣,在子頁面的周期函數(shù)mounted中監(jiān)聽父頁面發(fā)來的消息


vue與html之間iframe交互
1.父級調(diào)用子級ifram中的方法
document.getElementById(“id”).contentWindow.func()
id為iframe的id,func為引入iframe中的方法
2.子級iframe(html 或者vue)調(diào)用父級html中的方法
window.parent.func()
func為父級html的方法
3.vue中調(diào)用子級iframe html 中的方法
this.$refs.iframe.contentWindow.func()
4.在iframe中調(diào)用vue中的方法
先把vue中的方法暴露到window對象上
created(){
let _this = this
? ? ? ? window.funcname = ()=>{
? ? ? ? //vue中的方法
? ? ? ? ? ? ? _this.func() ? ? ?
? ? ? ? }
? ? } ? ?在iframe中調(diào)用
window.parent.funcname()
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue+element使用動態(tài)加載路由方式實(shí)現(xiàn)三級菜單頁面顯示的操作
這篇文章主要介紹了vue+element使用動態(tài)加載路由方式實(shí)現(xiàn)三級菜單頁面顯示的操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08
關(guān)于vue設(shè)置環(huán)境變量全流程
這篇文章主要介紹了關(guān)于vue設(shè)置環(huán)境變量全流程,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
Vue 頁面權(quán)限控制和登陸驗(yàn)證功能的實(shí)例代碼
這篇文章主要介紹了Vue 頁面權(quán)限控制和登陸驗(yàn)證功能的實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06
vue如何實(shí)現(xiàn)路由跳轉(zhuǎn)到外部鏈接界面
這篇文章主要介紹了vue如何實(shí)現(xiàn)路由跳轉(zhuǎn)到外部鏈接界面,具有很好的參考價(jià)值,希望對大家有所幫助。2022-10-10
Vue中watch監(jiān)聽屬性新舊值相同的問題解決方案
這篇文章主要給大家分享了Vue中watch監(jiān)聽屬性新舊值相同問題解決方案,如果有遇到相同問題的朋友,可以參考閱讀本文2023-08-08
vue使用監(jiān)聽實(shí)現(xiàn)全選反選功能
最近做的項(xiàng)目用到了全選全不選功能,于是我就自己動手寫了一個(gè),基于vue使用監(jiān)聽實(shí)現(xiàn)全選反選功能,具體實(shí)例代碼大家參考下本文2018-07-07
vue移動端實(shí)現(xiàn)左滑編輯與刪除的全過程
vue.js是現(xiàn)在流行的js框架之一,vue 是一套用于構(gòu)建用戶界面的漸進(jìn)式j(luò)avascript框架,這篇文章主要給大家介紹了關(guān)于vue移動端實(shí)現(xiàn)左滑編輯與刪除的相關(guān)資料,需要的朋友可以參考下2021-05-05
vue3+echarts+折線投影(陰影)效果的實(shí)現(xiàn)
這篇文章主要介紹了vue3+echarts+折線投影(陰影)效果的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
如何配置vue.config.js 處理static文件夾下的靜態(tài)文件
這篇文章主要介紹了如何配置vue.config.js 處理static文件夾下的靜態(tài)文件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06

