本文实例讲述了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,AOP编程
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
金钱帮资源网 Copyright www.kbjia.com
暂无“JavaScript AOP编程实例”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年10月19日
2024年10月19日
- 群星《歌手2024 第4期》[FLAC/分轨][563.76MB]
- RiffKitten-ChaosParade(2024)[24-44,1]FLAC
- RuneKlakegg-Nattevandrer(2024)[24-96]\FLAC
- 赖冰霞.2006-金嗓典藏辑2IN1(南方金点系列)2CD【南方】【WAV+CUE】
- 群星.1988-国语金曲尽精英VOL.2【瑞成】【WAV+CUE】
- 张宇.1999-雨一直下【EMI百代】【WAV+CUE】
- 袁娅维.2021-月亮失眠了(DELUXE)【华纳】【FLAC分轨】
- AlanBroadbent-JazzFunk(2024)[24-44,1]
- 梅艳芳《绝代芳华》开盘母带[低速原抓WAV+CUE]
- ABC唱片-《外国精逊母带直刻神奇黑胶[APE+CUE].
- 群星《天赐的声音第五季 第6期》[320K/MP3][101.43MB]
- 群星《天赐的声音第五季 第6期》[FLAC/分轨][526.16MB]
- 群星《说唱梦工厂 第2期》[320K/MP3][96.37MB]
- 杨宗宪.1994-留你留袂着【有容唱片】【WAV+CUE】
- 李翊君.2005-勇敢的爱【创意唱片】【WAV+CUE】