JavaScript之AOP编程实例


Posted in Javascript onJuly 17, 2015

本文实例讲述了JavaScript之AOP编程。分享给大家供大家参考。具体如下:

/*
// aop({options});
// By: adamchow2326@yahoo.com.au
// Version: 1.0
// Simple aspect oriented programming module
// support Aspect before, after and around
// usage:
    aop({
      context: myObject,   // scope context of the target function.
      target: "test",     // target function name
      before: function() {  // before function will be run before the target function
        console.log("aop before");
      },
      after: function() {   // after function will be run after the target function
        console.log("aop after");
      },
      around: function() {  // around function will be run before and after the target function
        console.log("aop around");
      }
    });
*/
var aop = (function() {
  var options = {},
    context = window,
    oFn,
    oFnArg,
    targetFn,
    targetFnSelector,
    beforeFn,
    afterFn,
    aroundFn,
    cloneFn = function(Fn) {
      if (typeof Fn === "function") {
        return eval('[' +Fn.toString()+ ']')[0];
      }
      return null;
    },
    checkContext = function() {
      if (options.context) {
        context = options.context;
      }
      if (typeof context[(options.target).name] === "function") {
        targetFnSelector = (options.target).name;
        targetFn = context[targetFnSelector];
      }
      else if (typeof context[options.target] === "function") {
        targetFnSelector = options.target;
        targetFn = context[targetFnSelector];
      }
      if (targetFn) {
        oFn = cloneFn(targetFn);
        oFnArg = new Array(targetFn.length);
        return true;
      }
      else {
        return false;
      }
    },
    run = function() {
      context[targetFnSelector] = function(oFnArg) {
        if (aroundFn){
          aroundFn.apply(this, arguments);
        }
        if (beforeFn){
          beforeFn.apply(this, arguments); // 'this' is context
        }
        oFn.apply(this, arguments);
        if (afterFn){
          afterFn.apply(this, arguments); // 'this' is context
        }
        if (aroundFn){
          aroundFn.apply(this, arguments);
        }
      };
    };
  return function(opt){
    if (opt && typeof opt === "object" && !opt.length) {
      options = opt;
      if (options.target && checkContext()) {
        if (options.before && typeof options.before === "function") {
          beforeFn = options.before;
        }
        if (options.after && typeof options.after === "function") {
          afterFn = options.after;
        }
        if (options.around && typeof options.after === "function") {
          aroundFn = options.around;
        }
        run();
      }
    }
  };
})();
// test examples
// ----------------- aop modify global function ---------------//
function test(name, age) {
  console.log("test fn. name = " + name + " age: " + age);
}
aop({
  target: "test",
  before: function() {
    console.log("aop before");
  },
  after: function() {
    console.log("aop after");
  },
  around: function() {
    console.log("aop around");
  }
});
// run
test("adam", 6);
// ----------------- aop test modify method in an object ---------------//
var myobj = {
  myName: "testName",
  sayName: function() {
    console.log(this.myName);
  },
  childObj: {
    age: 6,
    say: function() {
      console.log(this.age);
    }
  }
};
aop({
  context: myobj,
  target: "sayName",
  before: function() {
    console.log("aop before say name = " + this.myName);
  },
  after: function() {
    console.log("aop after say name = " + this.myName);
  },
  around: function() {
    console.log("aop around say name = " + this.myName);
  }
});
// run
myobj.sayName();
aop({
  context: myobj.childObj,
  target: "say",
  before: function() {
    console.log("aop before say name = " + this.age);
  },
  after: function() {
    console.log("aop after say name = " + this.age);
  },
  around: function() {
    console.log("aop around say name = " + this.age);
  }
});
myobj.childObj.say();

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
js call方法详细介绍(js 的继承)
Nov 18 Javascript
js简单的表格添加行和删除行操作示例
Mar 31 Javascript
js实现局部页面打印预览原理及示例代码
Jul 03 Javascript
jQuery实现tab选项卡效果的方法
Jul 08 Javascript
jQuery实现文件上传进度条特效
Aug 12 Javascript
JavaScript中的Number数字类型学习笔记
May 26 Javascript
Bootstrap 3 进度条的实现
Feb 22 Javascript
node作为中间服务层如何发送请求(发送请求的实现方法详解)
Jan 02 Javascript
基于vue 动态加载图片src的解决方法
Feb 05 Javascript
vue调试工具vue-devtools安装及使用方法
Nov 07 Javascript
解决vue中el-tab-pane切换的问题
Jul 19 Javascript
JS前端轻量fabric.js系列物体基类
Aug 05 Javascript
js+html5实现可在手机上玩的拼图游戏
Jul 17 #Javascript
javascript封装的sqlite操作类实例
Jul 17 #Javascript
js实现头像图片切割缩放及无刷新上传图片的方法
Jul 17 #Javascript
javascript实现根据3原色制作颜色选择器的方法
Jul 17 #Javascript
javascript实现树形菜单的方法
Jul 17 #Javascript
JSON与XML优缺点对比分析
Jul 17 #Javascript
浅谈jQuery的offset()方法及示例分享
Jul 17 #Javascript
You might like
Joomla下利用configuration.php存储简单数据
2010/05/19 PHP
php中用加号与用array_merge合并数组的区别深入分析
2013/06/03 PHP
php创建基本身份认证站点的方法详解
2013/06/08 PHP
Laravel 4 初级教程之Pages、表单验证
2014/10/30 PHP
php实现的生成排列算法示例
2019/07/25 PHP
php7连接MySQL实现简易查询程序的方法
2020/10/13 PHP
Aster vs KG BO3 第三场2.18
2021/03/10 DOTA
Mootools 1.2教程 正则表达式
2009/09/15 Javascript
EXTJS内使用ACTIVEX控件引起崩溃问题的解决方法
2010/03/31 Javascript
Javascript 网页黑白效果实现代码(兼容IE/FF等)
2010/04/23 Javascript
网页编辑器ckeditor和ckfinder配置步骤分享
2012/05/24 Javascript
JQuery之focus函数使用介绍
2013/08/20 Javascript
使用AngularJS实现表单向导的方法
2015/06/19 Javascript
javascript实现下班倒计时效果的方法(可桌面通知)
2015/07/10 Javascript
Listloading.js移动端上拉下拉刷新组件
2016/08/04 Javascript
Vue自定义组件双向绑定实现原理及方法详解
2020/09/03 Javascript
vue使用canvas实现移动端手写签名
2020/09/22 Javascript
[05:31]干嘛呢兄弟!DOTA2 TI9语音轮盘部分出处
2019/05/14 DOTA
Python内建数据结构详解
2016/02/03 Python
Python实现一个Git日志统计分析的小工具
2017/12/14 Python
VScode编写第一个Python程序HelloWorld步骤
2018/04/06 Python
django+mysql的使用示例
2018/11/23 Python
11个Python Pandas小技巧让你的工作更高效(附代码实例)
2019/04/30 Python
html5 touch事件实现触屏页面上下滑动(二)
2016/03/10 HTML / CSS
乐天旅游香港网站:日本饭店预订
2017/11/29 全球购物
FC-Moto西班牙:摩托车手最大的购物场所之一
2019/04/11 全球购物
什么是属性访问器
2015/10/26 面试题
建筑人员岗位职责
2013/12/25 职场文书
职务聘任书范文
2014/03/29 职场文书
委托书范文
2014/04/02 职场文书
反腐倡廉演讲稿
2014/05/22 职场文书
投标服务承诺书
2014/05/28 职场文书
助人为乐模范事迹材料
2014/06/02 职场文书
小学绿色学校申报材料
2014/08/23 职场文书
教师学习十八届五中全会精神心得体会
2016/01/05 职场文书
神州牡丹园的导游词
2019/11/20 职场文书