olympus-r
Version:
一个力求简单易用的前端开发框架 #### 开发语言 TypeScript #### 核心架构 MVC #### 模块间通讯和解耦 采用事件机制,利用一个全局唯一的事件派发器进行模块间通讯,解耦模块间依赖 #### 表现层结构 使用桥接模式拆分接口与实现,达到一套核心驱动多套表现层的目的(目前支持DOM、Egret、PixiJS三种表现层),同时支持表现层的未来可扩展性 #### TypeScript装饰器注入 框架提供TypeScript装饰器注入功能,便捷获取托管对象。例如:
49 lines (48 loc) • 1.18 kB
JavaScript
/**
* @author Raykid
* @email initial_r@qq.com
* @create date 2018-05-16
* @modify date 2018-05-16
*
* HTML相关工具
*/
/**
* 获取当前所在的容器iframe,如果没有则返回null
*
* @export
* @returns {(HTMLIFrameElement|null)}
*/
export function getIFrameContainer() {
var parentWindow = window.parent;
if (!parentWindow)
return null;
var tempIFrames = parentWindow.document.getElementsByTagName("iframe");
for (var i = 0, len = tempIFrames.length; i < len; i++) {
var tempIFrame = tempIFrames[i];
// 如果寻找到的iframe中的window和当前window一致,则返回之
if (tempIFrame.contentWindow === window)
return tempIFrame;
}
return null;
}
/**
* 获取最根节点的Window实例
*
* @export
* @returns {Window}
*/
export function getRootWindow() {
var curWindow = window;
while (curWindow.parent)
curWindow = curWindow.parent;
return curWindow;
}
/**
* 获取当前是否在iframe中
*
* @export
* @returns {boolean}
*/
export function isInIframe() {
return (getIFrameContainer() !== null);
}