JavaScript中AOP的实现与应用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JavaScript中AOP的实现与应用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3709字,纯文字阅读大概需要6分钟。
内容图文
![JavaScript中AOP的实现与应用](/upload/InfoBanner/zyjiaocheng/332/4a4c5c6c21d54f3aa566117c17ef0455.jpg)
1. 简介
AOP (Aspect Oriented Programming) ,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续,是函数式编程的一种衍生,利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。
2. 基础实现
使用过java spring的同学一定知道,其内分为三种通知,before(前置通知)、after(后置通知)、around(环绕通知)。
下面我们分别在js调用方法时实现这三种通知:
before(前置通知)
顾名思义,就是在函数调用前执行
Function.prototype.before = function (beforefun) { var _orgin = this; // 保存原函数引用 return function () { // 返回包含了原函数和新函数的"代理函数" beforefun.apply(this, arguments); // 执行新函数,修正this return _orgin.apply(this, arguments); // 执行原函数 } }; var originFun = function(val){ console.log('原型函数: '+val); } var newFun = originFun.before(function(){ // 传入函数调用前处理方法 console.log('before: ' + new Date().getTime()) }) newFun("测试前置通知"); // 调用结果 // before: 1557047939699 // 原型函数: 测试前置通知
after(后置通知)
与before正相反,在函数调用后执行
Function.prototype.after = function (afterfun) { var _orgin = this; // 保存原函数引用 return function () { // 返回包含了原函数和新函数的"代理函数" var ret = _orgin.apply(this, arguments); // 执行原函数 afterfun.apply(this, arguments); // 执行新函数,修正this return ret; } }; var originFun = function(val){ console.log('原型函数: '+val); } var newFun = originFun.after(function(){ // 传入函数调用前处理方法 console.log('after: ' + new Date().getTime()) }) newFun("测试后置通知"); // 调用结果 // 原型函数: 测试前置通知 // after: 1557047997647
around(环绕通知)
在方法执行前后分别执行
// 利用前面的before、after方法实现 Function.prototype.around = function(beforeFun, afterFun) { var _orgin = this; return function() { return _orgin.before(beforeFun).after(afterFun).apply(this, arguments); } }
3. AOP遇到修饰器
JS在ES7的提案中终于增加了修饰器(Decorator)函数,它是用来修改类的行为,但是现在浏览器都不支持,需要使用Babel进行转换,当AOP与修饰器结合后,又会给我们带来什么呢?
日志记录
通过AOP与修饰器的结合会很方便的进行日志的记录或者函数执行时间的记录
class Person { @log say(nick) { return `hi ${nick}`; } } function log(target, name, decriptor){ var _origin = descriptor.value; descriptor.value = function(){ console.log(`Calling ${name} with `, argumants); return _origin.apply(null, arguments); }; return descriptor; } var person = new Person(); person.say('小明');
判断用户登录状态
class User { @checkLogin getUserInfo() { console.log('获取用户信息') } } // 检查用户是否登录 function checkLogin(target, name, descriptor) { let method = descriptor.value descriptor.value = function (...args) { // 校验方法,假设这里可以获取到用户名/密码 if (validate(args)) { method.apply(this, args) } else { console.log('没有登录,即将跳转到登录页面...') } } } let user = new User() user.getUserInfo()
4. React中的AOP
在react中使用AOP思想的典型就是高阶组件(HOC),请看下面的例子
function HOCComp(WrappedComponent){ return class HOC extends Component { render(){ const newProps = {param: 'HOC'}; return <div> <WrappedComponent {...this.props} {...newProps}/> </div> } } } @HOCComp class OriginComponent extends Component { render(){ return <div>这是原始组件{this.props.param}</div> } }
上面例子中在HOCComp中定义新的props,并传入子组件中。我们也可以对OriginComponent组件中的一些props进行加工,或对OriginComponent外层进行再次包装。从而不必去修改内部组件,保持了功能上的解耦。
5. 总结
AOP思想在框架及项目中使用的很多,包括React高阶组件、日志记录、登录验证、redux中间件等。在开发中应该与OOP相辅相成,共同提高软件的健壮性及可维护性。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
参考资料
- https://www.gxlcms.com/article/160748.htm
- https://www.gxlcms.com/article/160753.htm
内容总结
以上是互联网集市为您收集整理的JavaScript中AOP的实现与应用全部内容,希望文章能够帮你解决JavaScript中AOP的实现与应用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。