使用局部上下文创建控制器对象

简介: 使用局部上下文创建控制器对象

创建绑定this上下文环境的并且可重用的控制器对象,

//this使用局部上下文基础模型
(function($, exports){
var mod = function(includes){
  if(includes) this.include(includes);
 };
 mod.fn = mod.prototype;
//将函数上下文this绑定到mod上
 mod.fn.proxy = function(func){
  return $.proxy(func, this);
 };
//documentContent加载完后执行相应的func回调
 mod.fn.load = function(func){
  $(this.proxy(func));
 };
//扩展prototype的方法
 mod.fn.include = function(ob){
  $.extend(this, ob);
 };
//导出为Controller全局对象
 exports.Controller = mod;
})(jQuery, window);
//给局部上下文模型扩展方法
Controller.fn.unload = function(func){
 jQuery(window).bind('unload', this.proxy(func));
};
//创建Controller对象模块
(function($, Controller){
var mod = new Controller;
mod.toggleClass = function(e){
 console.log(this);
this.view.toggleClass('over', e.data);
};
//文档加载完毕,可视作window.onload
mod.load(function(){
this.view = $('#view');
//绑定mod实例到this.goggleClass,以防止toggleClass内的this指向mouseover事件函数
this.view.bind('mouseover', true, this.proxy(this.toggleClass));
this.view.bind('mouseout', false, this.proxy(this.toggleClass));
});
var abc = function(aa){
 console.log(1111);
};
mod.include({abc:abc});
//test 创建第二个控制器对象
var mod1 = new Controller();
console.log(mod1);
})(jQuery, Controller);

================================我是分割 线==========================================

 

第一步:创建控制器模型

这里最主要的是使用了jquery的$.proxy函数来实现上下文的绑定,并且使用exports.Controller方式来爆露导出mod方式,减少了全局对象的污染

第二步:生成控制器模型对象

每一个控制器内都可创建了控制器模型的实例,这样就通过prototype继承方式继承了load等所有函数

相关文章
|
2月前
|
移动开发 前端开发 JavaScript
全局属性和局部属性有什么区别?
【10月更文挑战第27天】全局属性和局部属性在HTML中各自发挥着重要的作用,共同构建了丰富多样、功能强大的HTML文档。全局属性提供了通用的基础功能和结构支持,而局部属性则针对不同元素的特定需求实现了各种具体的功能和语义表达,两者相互配合,使得HTML能够更好地满足各种网页开发的需求。
|
3月前
|
存储
局部对象和全局对象之间的区别是什么
【10月更文挑战第19天】局部对象和全局对象之间的区别是什么
58 2
|
4月前
|
安全 Go 开发者
使用 contextvars 管理上下文变量
使用 contextvars 管理上下文变量
65 0
|
5月前
|
机器学习/深度学习 自然语言处理
上下文无关与上下文相关
上下文无关与上下文相关
|
5月前
|
Java 数据库连接 数据库
|
6月前
|
机器学习/深度学习 资源调度 Java
【YOLOv8改进 - 注意力机制】GC Block: 全局上下文块,高效捕获特征图中的全局依赖关系
YOLOv8专栏探讨了目标检测的创新改进,如整合NLNet和SENet优势的GCBlock,用于高效全局上下文建模。GCNet在多个识别任务中表现优越,同时降低了计算成本。文章提供了论文、代码链接及详细实现,包括特征的全局建模、变换和融合步骤。核心GCBlock代码展示了其结构。更多实战案例和配置见相关链接。
|
8月前
|
设计模式 缓存 安全
代理模式:解析对象间的间接访问与控制
代理模式:解析对象间的间接访问与控制
|
监控 Python
Python函数-上下文管理器
Python函数-上下文管理器
63 0
|
算法 C++ 容器
关系类算法函数
关系类算法函数
|
Java 编译器
深入探索: 对象构造的隐藏功能与技巧
深入探索: 对象构造的隐藏功能与技巧
107 0