iframe和父页面消息通信

一、需求iframe和父页面消息通信(Vue + Element UI项目

二、实现

基类plugin.postMessage.js

TypeScript 复制代码
;
let SAFEORIGIN = process.env.VUE_APP_SAFE_ACCESS_ORIGIN;
let origin = "*";
let THAT;
let mark = [];
function __(args,origin){
    if( window.top !== window.self ){
        window.parent.postMessage( args , origin || "*");
    }
};
function message(){
    if( window ){
        if( window.top === window.self ){
            return THAT.prototype.$message.apply(THAT, arguments );
        }else{
            __( { __: 'post', __type: "message", args : [].slice.apply(arguments) } );
            return Promise.resolve();
        };
    }

};
message.error = function(){
    if( window ){
        if( window.top === window.self ){
            return THAT.prototype.$message.error.apply(THAT, arguments );
        }else{
            __( { __: 'post', __type: "error", args : [].slice.apply(arguments) } );
            return Promise.resolve();
        };
    }
};
function confirm(){
    if( window ){
        if( window.top === window.self ){
            return THAT.prototype.$confirm.apply(THAT, arguments );
        }else{
            let __time = btoa( ( new Date).valueOf() );
			if( mark.indexOf( __time ) < 0 ){
				mark= [__time ];
			}else{
				do{
					__time += "1";
				}while(mark.indexOf( __time ) >= 0 );
				mark.push( __time )
			}
			
			
            return new Promise( (resolve,reject) => {
                let _ =  e => {
                    if( e.data && e.data["__"] ==="response" && e.data["__time"] === __time ){
                        if( e.data['__response'] === "resolve" ){
                            resolve( !0 )
                        }else{
                            reject( !1 );
                        }
                        window.removeEventListener( 'message' , _ );
                    }
                }
                window.addEventListener( 'message' , _ );
                __( { __time, __: "request", __type: "confirm" , args : [].slice.apply(arguments)  } );
            });

        }
    }else{
        return Promise.reject( new Error );
    }
};
function testPostMessageSafe(){
    let __time = btoa( ( new Date).valueOf() );
	if( mark.indexOf( __time ) < 0 ){
		mark= [__time ];
	}else{
		do{
			__time += "1";
		}while(mark.indexOf( __time ) >= 0 );
		mark.push( __time )
	}
    return new Promise( ( resolve, reject ) => {
        let _ = e => {
            if( e && e.data && e.data[ "__time" ] === __time && e.data[ "__" ] === "response" && e.data[ "__response"] ==="test"){
                origin = e.origin;
                if( SAFEORIGIN && SAFEORIGIN.split(',').indexOf( origin ) > -1 ){
                    resolve( origin );
                }else{
                    reject( -1 )
                }
                window.removeEventListener( "message" , _ );
            }
        }
        window.addEventListener( "message" , _ );
        __( { __: "request" , args , __time } );
    })
};
function postDirect( directName, args, safe ){
    if( safe ){
        testPostMessageSafe().then(() => {
            __({ __ : "direct", __direct: directName ,args, origin });
        }).catch( ()=>{})
    }else{
        __( { __: "direct", __direct: directName , args } );
    }
};
function sendMessage( args , safe ){
    if( safe ){
        testPostMessageSafe().then(() => {
            __( { __: "post", args, origin } );
        }).catch( ()=>{})
    }else{
        __({ __: "post", args });
    }
};
function requestMessage( args,safe ){
    if( window && window.top !== window.self ){
        function req(){
            let __time = btoa( ( new Date).valueOf() );
			if( mark.indexOf( __time ) < 0 ){
				mark= [__time ];
			}else{
				do{
					__time += "1";
				}while(mark.indexOf( __time ) >= 0 );
				mark.push( __time )
			}
            return new Promise( ( resolve, reject ) => {
                let _ = e => {
                    if( e && e.data && e.data[ "__time" ] === __time && e.data[ "__" ] === "response" ){
						if( e.data[ "__response"]  === "reject" ){
                            reject( e.data[ "args" ] )
                        }else{
                            resolve( e.data[ "args"] )
                        }
                        window.removeEventListener( "message" , _ );
                    }
                }
                window.addEventListener( "message" , _ );
                __( { __: "request" , args , __time } );
            })
        };
        if( safe ){
            return testPostMessageSafe().then(() => {
                return req();
            })
        }else{
            return req();
        }
    }else{
		return Promise.resolve();
	}
};
export default function( v ){
    THAT = v;
    if( v ){
        v.prototype.$$confirm = confirm;		//向外抛出 element UI confirm 弹层 , 接收返回处理
        v.prototype.$$message = message;		// 向外抛出 element UI Message 
        v.prototype.$$postDirect = postDirect;	//向外抛出带有事件名字的消息
        v.prototype.$$sendMessage = sendMessage;	//PostMessage
        v.prototype.$$requestMessage = requestMessage;	//向外请求带有参数消息,可接收返回值处理
        v.prototype.$$__ = __;
    }
}

iframe里发送消息给父页面

TypeScript 复制代码
if( window.self !== window.top && !this.framelimit ){
                    this.$nextTick( ()=>{
                        this.$$postDirect("resize",document.body.scrollHeight)
                    })
                }

父页面接收消息

window.addEventListener("message", this.__receiveMessage);

相关推荐
卿着飞翔1 天前
Vue使用yarn进行管理
前端·javascript·vue.js
夏天想1 天前
vue通过iframe引入一个外链地址,怎么保证每次切换回这个已经打开的tab页的时候iframe不会重新加载
前端·javascript·vue.js
GISer_Jing1 天前
2026年前端开发目标(From豆包)
前端·学习·aigc
CCPC不拿奖不改名1 天前
python基础面试编程题汇总+个人练习(入门+结构+函数+面向对象编程)--需要自取
开发语言·人工智能·python·学习·自然语言处理·面试·职场和发展
2501_944424121 天前
Flutter for OpenHarmony游戏集合App实战之数字拼图滑动交换
android·开发语言·flutter·游戏·harmonyos
偷星星的贼111 天前
C++中的访问者模式实战
开发语言·c++·算法
军军君011 天前
Three.js基础功能学习十一:动画与音频
前端·javascript·3d·js·threejs·三维
我即将远走丶或许也能高飞1 天前
reduxjs/toolkit 的学习使用
前端·javascript·学习·reactjs
Coder_Boy_1 天前
基于SpringAI的在线考试系统-知识点管理模块完整优化方案
java·前端·人工智能·spring boot
莫问前路漫漫1 天前
Java Runtime Environment(JRE)全解析:Java 程序跨平台运行的核心基石
java·开发语言