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 相关文章推荐
jQuery Ajax请求状态管理器打包
May 03 Javascript
JavaScript实现存储HTML字符串示例
Apr 21 Javascript
jQuery 回调函数(callback)的使用和基础
Feb 26 Javascript
浅析JavaScript 箭头函数 generator Date JSON
May 23 Javascript
详解node.js搭建代理服务器请求数据
Apr 08 Javascript
vue-router项目实战总结篇
Feb 11 Javascript
WebGL three.js学习笔记之阴影与实现物体的动画效果
Apr 25 Javascript
json数据格式常见操作示例
Jun 13 Javascript
使用layui的layer组件做弹出层的例子
Sep 27 Javascript
基于JavaScript实现猜数字游戏代码实例
Jul 30 Javascript
vue实现移动端触屏拖拽功能
Aug 21 Javascript
在vue中嵌入外部网站的实现
Nov 13 Javascript
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
PHP多线程抓取网页实现代码
2010/07/22 PHP
smarty简单入门实例
2014/11/28 PHP
php curl登陆qq后获取用户信息时证书错误
2015/02/03 PHP
迪菲-赫尔曼密钥交换(Diffie?Hellman)算法原理和PHP实现版
2015/05/12 PHP
php安装php_rar扩展实现rar文件读取和解压的方法
2016/11/17 PHP
Ubuntu彻底删除PHP7.0的方法
2018/07/27 PHP
PHP中Static(静态)关键字功能与用法实例分析
2019/04/05 PHP
JavaScript语言中的Literal Syntax特性分析
2007/03/08 Javascript
JavaScript异步调用定时方法并停止该方法实现代码
2012/03/16 Javascript
js switch case default 的用法示例介绍
2013/10/23 Javascript
举例详解Python中smtplib模块处理电子邮件的使用
2015/06/24 Javascript
浏览器中url存储的JavaScript实现
2015/07/07 Javascript
jQuery xml字符串的解析、读取及查找方法
2016/03/01 Javascript
浅析JS原型继承与类的继承
2016/04/07 Javascript
5种JavaScript脚本加载的方式
2017/01/16 Javascript
Angular实现搜索框及价格上下限功能
2018/01/19 Javascript
jQuery中DOM操作原则实例分析
2019/08/01 jQuery
解决vux 中popup 组件Mask 遮罩在最上层的问题
2020/11/03 Javascript
解决Element中el-date-picker组件不回填的情况
2020/11/07 Javascript
Python基于checksum计算文件是否相同的方法
2015/07/09 Python
python中单下划线_的常见用法总结
2018/07/10 Python
windows下numpy下载与安装图文教程
2019/04/02 Python
Keras 数据增强ImageDataGenerator多输入多输出实例
2020/07/03 Python
python3爬虫GIL修改多线程实例讲解
2020/11/24 Python
python 实现的IP 存活扫描脚本
2020/12/10 Python
房地产销售员的自我评价分享
2013/12/04 职场文书
十八大闭幕感言
2014/01/22 职场文书
自我反省检讨书
2014/01/23 职场文书
劳动之星获奖感言
2014/02/01 职场文书
学生自我评价范文
2014/02/02 职场文书
一份恶作剧的检讨书
2014/09/13 职场文书
2014年助理工程师工作总结
2014/11/14 职场文书
爱国主义教育基地观后感
2015/06/18 职场文书
担保书怎么写 ?
2019/04/22 职场文书
mysql数据插入覆盖和时间戳的问题及解决
2022/03/25 MySQL
redis 解决库存并发问题实现数量控制
2022/04/08 Redis