UNPKG

olympus-r

Version:

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

60 lines (59 loc) 1.91 kB
import "../../libs/Reflect"; import { listenConstruct } from "../../utils/ConstructUtil"; import { core } from "../Core"; import { decorateThis } from "../global/Patch"; /** * @author Raykid * @email initial_r@qq.com * @create date 2017-09-19 * @modify date 2017-09-19 * * Core模组的装饰器注入模块 */ /** 生成类型实例并注入,可以进行类型转换注入(即注入类型可以和注册类型不一致,采用@Injectable(AnotherClass)的形式即可) */ export function Injectable() { var args = []; for (var _i = 0; _i < arguments.length; _i++) { args[_i] = arguments[_i]; } if (this === decorateThis) { // 不需要转换注册类型,直接注册 core.mapInject(args[0]); } else { // 需要转换注册类型,需要返回一个ClassDecorator return function (realCls) { for (var _i = 0, args_1 = args; _i < args_1.length; _i++) { var cls = args_1[_i]; // 注入类型 core.mapInject(realCls, cls); } // 需要转换的也要额外将自身注入一个 core.mapInject(realCls); }; } } ; export function Inject(target, key) { if (key) { var cls = Reflect.getMetadata("design:type", target, key); doInject(target.constructor, key, cls); } else { return function (prototype, propertyKey) { doInject(prototype.constructor, propertyKey, target); }; } } ; function doInject(cls, key, type) { // 监听实例化 var target; listenConstruct(cls, function (instance) { Object.defineProperty(instance, key, { configurable: true, enumerable: true, get: function () { return target || (target = core.getInject(type)); } }); }); }