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 相关文章推荐
VBScript版代码高亮
Jun 26 Javascript
如何获取JQUERY AJAX返回的JSON结果集实现代码
Dec 10 Javascript
HTML5+setCutomValidity()函数验证表单实例分享
Apr 24 Javascript
jquery动态添加文本并获取值的方法
Oct 12 Javascript
html5+canvas实现支持触屏的签名插件教程
May 08 Javascript
layer弹窗插件操作方法详解
May 19 Javascript
react router 4.0以上的路由应用详解
Sep 21 Javascript
最新Javascript程序员面试试题和解题方法
Nov 23 Javascript
Vue+jquery实现表格指定列的文字收缩的示例代码
Jan 09 jQuery
JS 实现分页打印功能
May 16 Javascript
详解如何用typescript开发koa2的二三事
Nov 13 Javascript
有关vue 开发钉钉 H5 微应用 dd.ready() 不执行问题及快速解决方案
May 09 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 MSSQL 存储过程的方法
2008/12/24 PHP
利用PHP扩展vld查看PHP opcode操作步骤
2013/03/04 PHP
dhtmlxTree目录树增加右键菜单以及拖拽排序的实现方法
2013/04/26 PHP
解析php中const与define的应用区别
2013/06/18 PHP
如何利用PHP执行.SQL文件
2013/07/05 PHP
php批量删除数据库下指定前缀的表以prefix_为例
2014/08/24 PHP
php连接mysql数据库
2017/03/21 PHP
Laravel 5.5 的自定义验证对象/类示例代码详解
2017/08/29 PHP
Laravel多域名下字段验证的方法
2019/04/04 PHP
Laravel 框架基于自带的用户系统实现登录注册及错误处理功能分析
2020/04/14 PHP
SyntaxHighlighter代码加色使用方法
2008/09/07 Javascript
利用webqq协议使用python登录qq发消息源码参考
2013/04/08 Javascript
JQuery中DOM加载与事件执行实例分析
2015/06/13 Javascript
Angular.JS利用ng-disabled属性和ng-model实现禁用button效果
2017/04/05 Javascript
原生JS写Ajax的请求函数功能
2017/12/22 Javascript
vue响应式系统之observe、watcher、dep的源码解析
2019/04/09 Javascript
vue 使用鼠标滚动加载数据的例子
2019/10/31 Javascript
vue搜索页开发实例代码详解(热门搜索,历史搜索,淘宝接口演示)
2020/04/11 Javascript
Vue实现图书管理案例
2021/01/20 Vue.js
探究Python的Tornado框架对子域名和泛域名的支持
2015/05/02 Python
python爬虫实战之最简单的网页爬虫教程
2017/08/13 Python
Python3利用Dlib19.7实现摄像头人脸识别的方法
2018/05/11 Python
详解Python3.6安装psutil模块和功能简介
2018/05/30 Python
详解Python利用random生成一个列表内的随机数
2019/08/21 Python
解决Django响应JsonResponse返回json格式数据报错问题
2020/08/09 Python
css3实现元素环绕中心点布局的方法示例
2019/01/15 HTML / CSS
详解快速开发基于 HTML5 网络拓扑图应用
2018/01/08 HTML / CSS
洲际酒店集团英国官网:IHG英国
2019/07/10 全球购物
房地产财务部员工岗位职责
2014/03/12 职场文书
公司请假条格式
2014/04/11 职场文书
人力资源管理求职信
2014/08/07 职场文书
领导干部遵守党的政治纪律情况思想汇报
2014/09/14 职场文书
全国法制宣传日活动总结2014
2014/11/01 职场文书
2014年医务科工作总结
2014/12/18 职场文书
西安兵马俑导游词
2015/02/02 职场文书
村级干部党员公开承诺事项
2015/05/04 职场文书