vue與iframe之間的交互方式(一看就會)
vue與iframe之間的交互
首先介紹一下使用背景,前端采用html單頁面引用vue的方式(逼不得已這么做,否則直接用vue不香嘛),廢話不多說
頁面大致是這樣,現(xiàn)在需要做的是在iframe頁面里面觸發(fā)事件跳轉頁面,并且使父級vue頁面的左側菜單選中相應頁面的菜單,當然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)髦狄簿蜁?,就是吧一二步驟調換未知
1.在父頁面中觸發(fā)事件傳遞參數(shù),在父頁面通過ref來得到iframe子頁面的dom元素,然手使用postMessage傳參。
另:通過ref獲取dom,父頁面的iframe標簽里寫ref就行
2.和上面一樣,在子頁面的周期函數(shù)mounted中監(jiān)聽父頁面發(fā)來的消息
vue與html之間iframe交互
1.父級調用子級ifram中的方法
document.getElementById(“id”).contentWindow.func()
id為iframe的id,func為引入iframe中的方法
2.子級iframe(html 或者vue)調用父級html中的方法
window.parent.func()
func為父級html的方法
3.vue中調用子級iframe html 中的方法
this.$refs.iframe.contentWindow.func()
4.在iframe中調用vue中的方法
先把vue中的方法暴露到window對象上
created(){ let _this = this ? ? ? ? window.funcname = ()=>{ ? ? ? ? //vue中的方法 ? ? ? ? ? ? ? _this.func() ? ? ? ? ? ? ? } ? ? } ? ?
在iframe中調用
window.parent.funcname()
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Vue實現(xiàn)動態(tài)創(chuàng)建和刪除數(shù)據的方法
下面小編就為大家分享一篇Vue實現(xiàn)動態(tài)創(chuàng)建和刪除數(shù)據的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03vue2+tracking實現(xiàn)PC端的人臉識別示例
本文主要介紹了vue2+tracking實現(xiàn)PC端的人臉識別示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05全局安裝 Vue cli3 和 繼續(xù)使用 Vue-cli2.x操作
這篇文章主要介紹了全局安裝 Vue cli3 和 繼續(xù)使用 Vue-cli2.x操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09vue3+elementPlus?table中添加輸入框并提交校驗
這篇文章主要介紹了vue3+elementPlus?table里添加輸入框并提交校驗,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08