UNPKG

olympus-r

Version:

一个力求简单易用的前端开发框架 #### 开发语言 TypeScript #### 核心架构 MVC #### 模块间通讯和解耦 采用事件机制,利用一个全局唯一的事件派发器进行模块间通讯,解耦模块间依赖 #### 表现层结构 使用桥接模式拆分接口与实现,达到一套核心驱动多套表现层的目的(目前支持DOM、Egret、PixiJS三种表现层),同时支持表现层的未来可扩展性 #### TypeScript装饰器注入 框架提供TypeScript装饰器注入功能,便捷获取托管对象。例如:

57 lines (56 loc) 1.59 kB
import Mediator from "../mediator/Mediator"; import IPanel from "./IPanel"; import IPanelPolicy from "./IPanelPolicy"; /** * @author Raykid * @email initial_r@qq.com * @create date 2017-09-06 * @modify date 2017-09-06 * @export * @class PanelMediator * @extends {Mediator<S, OD, CD>} * @implements {IPanel<S, OD, CD>} * @template S 皮肤类型 * @template OD 开启参数类型 * @template CD 关闭参数类型 * * 实现了IPanel接口的弹窗中介者基类 */ export default class PanelMediator<S = any, OD = any, CD = any> extends Mediator<S, OD, CD> implements IPanel<S, OD, CD> { /** * 弹出策略 * * @type {IPanelPolicy<S>} * @memberof PanelMediator */ policy: IPanelPolicy<S>; constructor(skin?: S, policy?: IPanelPolicy<S>); __afterOnOpen(data?: OD, isModel?: boolean, from?: { x: number; y: number; }): void; __afterOnClose(data?: CD, to?: { x: number; y: number; }): void; /** 在弹出前调用的方法 */ onBeforePop(data?: OD, isModel?: boolean, from?: { x: number; y: number; }): void; /** 在弹出后调用的方法 */ onAfterPop(data?: OD, isModel?: boolean, from?: { x: number; y: number; }): void; /** 在关闭前调用的方法 */ onBeforeDrop(data?: CD, to?: { x: number; y: number; }): void; /** 在关闭后调用的方法 */ onAfterDrop(data?: CD, to?: { x: number; y: number; }): void; }