olympus-r
Version:
一个力求简单易用的前端开发框架 #### 开发语言 TypeScript #### 核心架构 MVC #### 模块间通讯和解耦 采用事件机制,利用一个全局唯一的事件派发器进行模块间通讯,解耦模块间依赖 #### 表现层结构 使用桥接模式拆分接口与实现,达到一套核心驱动多套表现层的目的(目前支持DOM、Egret、PixiJS三种表现层),同时支持表现层的未来可扩展性 #### TypeScript装饰器注入 框架提供TypeScript装饰器注入功能,便捷获取托管对象。例如:
69 lines (68 loc) • 2.29 kB
JavaScript
import { getGUID, getObjectHashs } from "../../utils/ObjectUtil";
import Watcher from "./Watcher";
/**
* @author Raykid
* @email initial_r@qq.com
* @create date 2017-11-06
* @modify date 2017-11-06
*
* 一个绑定
*/
var Bind = /** @class */ (function () {
function Bind(mediator) {
this._watcherDict = {};
this._mediator = mediator;
}
Object.defineProperty(Bind.prototype, "mediator", {
/**
* 获取已绑定的中介者实例
*
* @readonly
* @type {IMediator}
* @memberof Bind
*/
get: function () {
return this._mediator;
},
enumerable: true,
configurable: true
});
/**
* 创建一个观察者,在数值变更时会通知回调进行更新
*
* @param {*} currentTarget 作用目标,指表达式所在的显示对象
* @param {*} target 绑定表达式本来所在的对象
* @param {EvalExp} exp 表达式或方法
* @param {WatcherCallback} callback 订阅器回调
* @param {*} thisArg this指向
* @param {...any[]} scopes 作用域列表,最后一个作用域会被当做this指向
* @returns {IWatcher} 返回观察者本身
* @memberof Bind
*/
Bind.prototype.createWatcher = function (currentTarget, target, exp, callback, thisArg) {
var scopes = [];
for (var _i = 5; _i < arguments.length; _i++) {
scopes[_i - 5] = arguments[_i];
}
var key = getObjectHashs.apply(void 0, [currentTarget, exp, getGUID()].concat(scopes));
var watcher = this._watcherDict[key];
if (!watcher)
this._watcherDict[key] = watcher = new (Watcher.bind.apply(Watcher, [void 0, this, currentTarget, target, exp, callback, thisArg].concat(scopes)))();
return watcher;
};
/**
* 销毁绑定关系
*
* @memberof Bind
*/
Bind.prototype.dispose = function () {
for (var key in this._watcherDict) {
var watcher = this._watcherDict[key];
watcher.dispose();
delete this._watcherDict[key];
}
this._mediator = null;
};
return Bind;
}());
export default Bind;