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 相关文章推荐
JavaScript的面向对象(一)
Nov 09 Javascript
关于Jquery操作Cookie取值错误的解决方法
Aug 26 Javascript
JavaScript日期时间格式化函数分享
May 05 Javascript
JavaScript按值删除数组元素的方法
Apr 24 Javascript
javascript动态生成树形菜单的方法
Nov 14 Javascript
jQuery仿写百度百科的目录树
Jan 03 Javascript
Cookies 和 Session的详解及区别
Apr 21 Javascript
使用 Node.js 开发资讯爬虫流程
Jan 07 Javascript
JavaScript模板引擎实现原理实例详解
Dec 14 Javascript
Webpack4 使用Babel处理ES6语法的方法示例
Mar 07 Javascript
koa router 多文件引入的方法示例
May 22 Javascript
手把手教你 CKEDITOR 4 实现Dialog 内嵌 IFrame操作详解
Jun 18 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
php面向对象全攻略 (十四) php5接口技术
2009/09/30 PHP
PHPStrom中实用的功能和快捷键大全
2015/09/23 PHP
使用xampp搭建运行php虚拟主机的详细步骤
2015/10/21 PHP
JS随机漂浮广告代码具体实例
2013/11/19 Javascript
javascript中数组的冒泡排序使用示例
2013/12/18 Javascript
常常会用到的截取字符串substr()、substring()、slice()方法详解
2015/12/16 Javascript
百度多文件异步上传控件webuploader基本用法解析
2016/11/07 Javascript
bootstrap轮播图示例代码分享
2017/05/17 Javascript
微信小程序图片横向左右滑动案例
2017/05/19 Javascript
underscore之Collections_动力节点Java学院整理
2017/07/10 Javascript
浅谈webpack打包之后的文件过大的解决方法
2018/03/07 Javascript
Vue SSR 组件加载问题
2018/05/02 Javascript
修改node.js默认的npm安装目录实例
2018/05/15 Javascript
node.js基础知识汇总
2020/08/25 Javascript
[04:50]2019DOTA2高校联赛秋季赛四强集锦
2019/12/27 DOTA
python 字典(dict)遍历的四种方法性能测试报告
2014/06/25 Python
python私有属性和方法实例分析
2015/01/15 Python
python 默认参数问题的陷阱
2016/02/29 Python
python编程培训 python培训靠谱吗
2018/01/17 Python
python日期时间转为字符串或者格式化输出的实例
2018/05/29 Python
Python程序包的构建和发布过程示例详解
2019/06/09 Python
python实现抠图给证件照换背景源码
2019/08/20 Python
PyCharm无法引用自身项目解决方式
2020/02/12 Python
python与c语言的语法有哪些不一样的
2020/09/13 Python
Python操控mysql批量插入数据的实现方法
2020/10/27 Python
Python3 用什么IDE开发工具比较好
2020/11/28 Python
Pytorch 图像变换函数集合小结
2021/02/01 Python
T3官网:头发造型工具
2019/12/26 全球购物
房地产销售员的自我评价分享
2013/12/04 职场文书
2014幼儿园家长工作总结
2014/11/10 职场文书
交通事故责任认定书
2015/08/06 职场文书
小学班长竞选稿
2015/11/20 职场文书
详解Laravel框架的依赖注入功能
2021/05/27 PHP
使用numpy实现矩阵的翻转(flip)与旋转
2021/06/03 Python
疑《守望先锋2》A测截图泄露 或将推出新模式、新界面
2022/04/03 其他游戏
使用vuex-persistedstate本地存储vuex
2022/04/29 Vue.js