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);

相关推荐
JAVA面经实录9176 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
陈随易7 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星7 小时前
javascript之事件代理/事件委托
前端
周杰伦fans7 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
陈随易8 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
Bat U9 小时前
JavaEE|多线程初阶(七)
java·开发语言
谭欣辰9 小时前
C++ 排列组合完整指南
开发语言·c++·算法
foundbug99910 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab
XDH_CS10 小时前
MySQL 8.0 安装与 MySQL Workbench 使用全流程(超详细教程)
开发语言·数据库·mysql