yui3的AOP(面向切面编程)和OOP(面向对象编程)


Posted in Javascript onMay 01, 2015

首先请把手放胸前成沉思状:我上了生活,还是被生活上了自己?

没想出答案把,恩,可以读下文了。从语义角度讲,同一事物的不同表述可以反映人的主观视角的不同,从哲学角度将,世界观影响方法论,我们看事物的角度不同,有时会得出截然相悖的结论,从而会影响我们的做事方式和行为准则,现实生活如此,在丰富多彩的编程语言中更是如此,编程模式充满了对现实世界的各种模拟,包括是面向过程,面向对象,还有面向切面。我们大概已经非常熟悉面向过程和面向对象,切面的英文是Aspects(有时译作方面,我感觉用切面更能贴切的表达Aspects的内涵)。

有关AOP的链接看这里:
http://en.wikipedia.org/wiki/Aspect-ori ... rogramming

YUI3中的自定义事件实现了AOP
http://developer.yahoo.com/yui/3/event

什么是切面?举个简单的例子,每天我们上下班挤地铁坐公交和女朋友约会上网吧打游戏去电影院看电影……,一天要做很多事情,每个人都是一个Object,我们做的每件事情都是这个Object的方法,比如,

甲.上班();
乙.坐地铁();
丙.看电影();

其实可以换个角度看,公司需要员工来上班,轨道交通需要每个人去乘坐,电影院给每个人放电影。这样就变成了:

公司.need(甲)
地铁.carry(乙);
电影院.放电影给(丙);

这样看来,不仅甲乙丙每个个体都是一个对象,公司、地铁、电影院也是对象,这种抽象就是传统的面向切面。而在js编程中,程序一般都不大,所以大概不会到达非要使用切面级别的抽象的程度。但其基于事件驱动的原理则很容易让人联想到AOP,上个例子在js中就可能是:

someone.dosth();//OOPobject.fire('event',someone);//AOP

如果脱离上下文来看,上面的代码依然语义牵强。只是很多js框架把切面编程的边缘特性封装成方法,对人造成了很多误导。比如事件的绑定。当函数foo执行结束的时候执行myfoo,在不修改foo的基础上来添加对foo的监听,

var foo = function(){
  //some code here
};

jQuery.aop.after(foo,function(){
  //added code here
});

jquery和prototype都实现了这种简单的函数绑定。jquery的aop在这里。但在yui3中,AOP则被提升至自定义事件的一种内在机制,在源码中随处可见。这在理解yui3的代码重用机制是很有帮助的。也正是得益于这种抽象使得yui3的自定义事件异常强大和灵活。和OOP相比,AOP的优点是非侵入式的“装饰”,但在多数情况下,并不推荐首先使用AOP来写代码。来看这个例子:每个人的生活习惯很类似,这里用四种行为为例,上学,放学,泡妞,打游戏,甲的生活规律很正常,每种事件发生的概率是一样的,乙是个贪玩的小孩,只会去网吧打游戏和泡妞,丙是一个爱学习的小孩,从不泡妞和打游戏,丁是一个经历超级旺盛的另类,每次都是同时干两件事情,上学的时候泡妞,放学的时候打游戏。这里用div代表每个人,用onmouseover来触发每个事件。

用OOP的方法那么程序结构应该是这样:

yui3的AOP(面向切面编程)和OOP(面向对象编程)

代码在这里:yui_oop.htm

这里的"古怪人"继承自"正常人"的时候,是通过代码重写的方法来达到重载的目的,这里明显违反了非侵入性原则。再来看AOP的思路:

yui3的AOP(面向切面编程)和OOP(面向对象编程)

代码在这里:yui_aop.htm

这里抽象出了事件发布工厂,用来专门处理事件的发布,由其生成的生活轨迹对象对每个人进行监听,捕捉每个人的各种行为。工厂在生成‘古怪人生活轨迹'的时候使用了上文提到的函数的监听绑定,这种绑定是非侵入性的,可以很好的和工厂解耦。从这个例子中比较OOP和AOP,两者复杂度差不多,但AOP思路更开阔,代码也更灵活一些。

Javascript 相关文章推荐
JS解析json数据并将json字符串转化为数组的实现方法
Dec 25 Javascript
jquery索引在使用中的一些困惑
Oct 24 Javascript
JavaScript头像上传插件源码分享
Mar 29 Javascript
AngularJS自定义服务与fliter的混合使用
Nov 24 Javascript
js实现开启密码大写提示
Dec 21 Javascript
js模块加载方式浅析
Aug 12 Javascript
浅谈在vue项目中如何定义全局变量和全局函数
Oct 24 Javascript
Node.JS循环删除非空文件夹及子目录下的所有文件
Mar 12 Javascript
Vue+Jwt+SpringBoot+Ldap完成登录认证的示例代码
May 21 Javascript
H5+C3+JS实现双人对战五子棋游戏(UI篇)
May 28 Javascript
JS监听滚动和id自动定位滚动
Dec 18 Javascript
详解利用eventemitter2实现Vue组件通信
Nov 04 Javascript
使用AOP改善javascript代码
May 01 #Javascript
Javascript aop(面向切面编程)之around(环绕)分析
May 01 #Javascript
jQuery插件Zclip实现完美兼容个浏览器点击复制内容到剪贴板
Apr 30 #Javascript
jQuery插件slider实现拖动滑块选取价格范围
Apr 30 #Javascript
javascript实现验证身份证号的有效性并提示
Apr 30 #Javascript
PHP+jQuery实现随意拖动层并即时保存拖动位置
Apr 30 #Javascript
jquery实现键盘左右翻页特效
Apr 30 #Javascript
You might like
Zend的Registry机制的使用说明
2013/05/02 PHP
WordPress中用于获取及自定义头像图片的PHP脚本详解
2015/12/17 PHP
PHP会员找回密码功能的简单实现
2016/09/05 PHP
PHP中include()与require()的区别说明
2017/02/14 PHP
更正确的asp冒泡排序
2007/05/24 Javascript
JavaScript 学习笔记 Black.Caffeine 09.11.28
2009/11/30 Javascript
使用jQuery快速解决input中placeholder值在ie中无法支持的问题
2014/01/02 Javascript
jquery.gridrotator实现响应式图片展示画廊效果
2015/06/23 Javascript
JS深度拷贝Object Array实例分析
2016/03/31 Javascript
Node.js中.pfx后缀文件的处理方法
2017/03/10 Javascript
Angular 1.x个人使用的经验小结
2017/07/19 Javascript
利用Vue实现移动端图片轮播组件的方法实例
2017/08/23 Javascript
ES6使用Set数据结构实现数组的交集、并集、差集功能示例
2017/10/31 Javascript
浅谈vue的props,data,computed变化对组件更新的影响
2018/01/16 Javascript
Javascript实现异步编程的过程
2018/06/18 Javascript
JS 实现获取验证码 倒计时功能
2018/10/29 Javascript
JS实现二维数组元素的排列组合运算简单示例
2019/01/28 Javascript
layui2.0使用table+laypage实现真分页
2019/07/27 Javascript
用Angular实现一个扫雷的游戏示例
2020/05/15 Javascript
微信小程序自定义modal弹窗组件的方法详解
2020/12/20 Javascript
python从入门到精通(DAY 1)
2015/12/20 Python
教大家使用Python SqlAlchemy
2016/02/12 Python
python将字典内容存入mysql实例代码
2018/01/18 Python
Python cookbook(数据结构与算法)字典相关计算问题示例
2018/02/18 Python
Django unittest 设置跳过某些case的方法
2018/12/26 Python
Python之使用adb shell命令启动应用的方法详解
2019/01/07 Python
Python删除n行后的其他行方法
2019/01/28 Python
Python qqbot 实现qq机器人的示例代码
2019/07/11 Python
通过celery异步处理一个查询任务的完整代码
2019/11/19 Python
用Python去除图像的黑色或白色背景实例
2019/12/12 Python
pytorch SENet实现案例
2020/06/24 Python
员工拾金不昧表扬信
2014/01/09 职场文书
未受刑事制裁公证证明
2014/09/20 职场文书
CocosCreator如何实现划过的位置显示纹理
2021/04/14 Javascript
CSS布局之浮动(float)和定位(position)属性的区别
2021/09/25 HTML / CSS
CentOS7和8下安装Maven3.8.4
2022/04/07 Servers