JavaScript AOP编程实例


Posted in Javascript onJune 16, 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 利用Cookie记录用户登录信息
Dec 08 Javascript
Tinymce+jQuery.Validation使用产生的BUG
Mar 29 Javascript
JQuery 自定义CircleAnimation,Animate方法学习笔记
Jul 10 Javascript
jQuery源码解读之hasClass()方法分析
Feb 20 Javascript
jQuery控制div实现随滚动条滚动效果
Jun 07 Javascript
Javascript 实现微信分享(QQ、朋友圈、分享给朋友)
Oct 21 Javascript
详解jQuery的表单验证插件--Validation
Dec 21 Javascript
js实现带简单弹性运动的导航条
Feb 22 Javascript
vue 2.0路由之路由嵌套示例详解
May 08 Javascript
Javascript实现秒表倒计时功能
Nov 17 Javascript
layer 关闭指定弹出层的例子
Sep 25 Javascript
Vue中引入svg图标的两种方式
Jan 14 Vue.js
js+HTML5基于过滤器从摄像头中捕获视频的方法
Jun 16 #Javascript
动态加载jQuery的方法
Jun 16 #Javascript
详解AngularJS中的表格使用
Jun 16 #Javascript
js+HTML5实现视频截图的方法
Jun 16 #Javascript
AngularJS中的过滤器使用详解
Jun 16 #Javascript
简述AngularJS的控制器的使用
Jun 16 #Javascript
详解AngularJS中的表达式使用
Jun 16 #Javascript
You might like
使用 eAccelerator加速PHP代码的目的
2007/03/16 PHP
php生成随机密码的三种方法小结
2010/09/04 PHP
PHP编程中的__clone()方法使用详解
2015/11/27 PHP
jQuery 表单验证插件formValidation实现个性化错误提示
2009/06/23 Javascript
jquery简单倒计时实现方法
2015/12/18 Javascript
jQuery自定义数值抽奖活动代码
2016/06/11 Javascript
jQuery双向列表选择器DIV模拟版
2016/11/01 Javascript
nodejs个人博客开发第七步 后台登陆
2017/04/12 NodeJs
nuxt中使用路由守卫的方法步骤
2019/01/27 Javascript
一文了解vue-router之hash模式和history模式
2019/05/31 Javascript
小程序实现按下录音松开识别语音
2019/11/22 Javascript
JavaScript实现单点登录的示例
2020/09/23 Javascript
深入Python函数编程的一些特性
2015/04/13 Python
pygame学习笔记(6):完成一个简单的游戏
2015/04/15 Python
python中as用法实例分析
2015/04/30 Python
Python3中简单的文件操作及两个简单小实例分享
2017/06/18 Python
python利用正则表达式搜索单词示例代码
2017/09/24 Python
基于python 处理中文路径的终极解决方法
2018/04/12 Python
对pandas里的loc并列条件索引的实例讲解
2018/11/15 Python
Python基于机器学习方法实现的电影推荐系统实例详解
2019/06/25 Python
python 计算平均平方误差(MSE)的实例
2019/06/29 Python
Python完成哈夫曼树编码过程及原理详解
2019/07/29 Python
python使用多线程编写tcp客户端程序
2019/09/02 Python
DRF框架API版本管理实现方法解析
2020/08/21 Python
Numpy中np.random.rand()和np.random.randn() 用法和区别详解
2020/10/23 Python
分享一个页面平滑滚动小技巧(推荐)
2019/10/23 HTML / CSS
HTML5 预加载让页面得以快速呈现
2013/08/13 HTML / CSS
Bodum官网:咖啡和茶壶、玻璃器皿、厨房电器等
2018/08/01 全球购物
线程同步的方法
2016/11/23 面试题
制冷与电控专业应届生求职信
2013/11/11 职场文书
综合实践活动总结
2014/05/05 职场文书
党支部综合考察材料
2014/05/19 职场文书
2015年驾驶员工作总结
2015/04/29 职场文书
小学生红领巾广播稿
2015/08/19 职场文书
Go 实现英尺和米的简单单位换算方式
2021/04/29 Golang
使用opencv-python如何打开USB或者笔记本前置摄像头
2022/06/21 Python