真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

怎么在JavaScript中實(shí)現(xiàn)AOP

本篇文章為大家展示了怎么在JavaScript中實(shí)現(xiàn)AOP,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

創(chuàng)新互聯(lián)公司是一家專注于做網(wǎng)站、網(wǎng)站設(shè)計(jì)和綿陽(yáng)電信機(jī)房機(jī)柜租用的網(wǎng)絡(luò)公司,有著豐富的建站經(jīng)驗(yàn)和案例。

1. 簡(jiǎn)介

AOP (Aspect Oriented Programming) ,意為:面向切面編程,通過(guò)預(yù)編譯方式和運(yùn)行期動(dòng)態(tài)代理實(shí)現(xiàn)程序功能的統(tǒng)一維護(hù)的一種技術(shù)。AOP是OOP的延續(xù),是函數(shù)式編程的一種衍生,利用AOP可以對(duì)業(yè)務(wù)邏輯的各個(gè)部分進(jìn)行隔離,從而使得業(yè)務(wù)邏輯各部分之間的耦合度降低,提高程序的可重用性,同時(shí)提高了開(kāi)發(fā)的效率。

怎么在JavaScript中實(shí)現(xiàn)AOP

2. 基礎(chǔ)實(shí)現(xiàn)

使用過(guò)java spring的同學(xué)一定知道,其內(nèi)分為三種通知,before(前置通知)、after(后置通知)、around(環(huán)繞通知)。
下面我們分別在js調(diào)用方法時(shí)實(shí)現(xiàn)這三種通知:

before(前置通知)

顧名思義,就是在函數(shù)調(diào)用前執(zhí)行

Function.prototype.before = function (beforefun) {
 var _orgin = this; // 保存原函數(shù)引用
 return function () { // 返回包含了原函數(shù)和新函數(shù)的"代理函數(shù)"
 beforefun.apply(this, arguments); // 執(zhí)行新函數(shù),修正this
 return _orgin.apply(this, arguments); // 執(zhí)行原函數(shù)
 }
};

var originFun = function(val){
 console.log('原型函數(shù): '+val);
}

var newFun = originFun.before(function(){
 // 傳入函數(shù)調(diào)用前處理方法
 console.log('before: ' + new Date().getTime())
})

newFun("測(cè)試前置通知");

// 調(diào)用結(jié)果
// before: 1557047939699
// 原型函數(shù): 測(cè)試前置通知

after(后置通知)

與before正相反,在函數(shù)調(diào)用后執(zhí)行

Function.prototype.after = function (afterfun) {
 var _orgin = this; // 保存原函數(shù)引用
 return function () { // 返回包含了原函數(shù)和新函數(shù)的"代理函數(shù)"
 var ret = _orgin.apply(this, arguments); // 執(zhí)行原函數(shù)
 afterfun.apply(this, arguments); // 執(zhí)行新函數(shù),修正this
 return ret;
 }
};

var originFun = function(val){
 console.log('原型函數(shù): '+val);
}

var newFun = originFun.after(function(){
 // 傳入函數(shù)調(diào)用前處理方法
 console.log('after: ' + new Date().getTime())
})

newFun("測(cè)試后置通知");

// 調(diào)用結(jié)果
// 原型函數(shù): 測(cè)試前置通知
// after: 1557047997647

around(環(huán)繞通知)

在方法執(zhí)行前后分別執(zhí)行

// 利用前面的before、after方法實(shí)現(xiàn)
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)函數(shù),它是用來(lái)修改類的行為,但是現(xiàn)在瀏覽器都不支持,需要使用Babel進(jìn)行轉(zhuǎn)換,當(dāng)AOP與修飾器結(jié)合后,又會(huì)給我們帶來(lái)什么呢?

日志記錄

通過(guò)AOP與修飾器的結(jié)合會(huì)很方便的進(jìn)行日志的記錄或者函數(shù)執(zhí)行時(shí)間的記錄

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('小明');

判斷用戶登錄狀態(tài)

class User {
 @checkLogin
 getUserInfo() {
 console.log('獲取用戶信息')
 }
}

// 檢查用戶是否登錄
function checkLogin(target, name, descriptor) {
 let method = descriptor.value
 descriptor.value = function (...args) {
 // 校驗(yàn)方法,假設(shè)這里可以獲取到用戶名/密碼
 if (validate(args)) {
 method.apply(this, args)
 } else {
 console.log('沒(méi)有登錄,即將跳轉(zhuǎn)到登錄頁(yè)面...')
 }
 }
}

let user = new User()
user.getUserInfo()

4. React中的AOP

在react中使用AOP思想的典型就是高階組件(HOC),請(qǐng)看下面的例子

function HOCComp(WrappedComponent){
 return class HOC extends Component {
 render(){
 const newProps = {param: 'HOC'};
 return 
   
 }  } } @HOCComp class OriginComponent extends Component {  render(){  return 
這是原始組件{this.props.param}
 } }

上述內(nèi)容就是怎么在JavaScript中實(shí)現(xiàn)AOP,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


分享標(biāo)題:怎么在JavaScript中實(shí)現(xiàn)AOP
轉(zhuǎn)載注明:http://weahome.cn/article/pdcdjh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部