博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript-装饰器函数(Decorator)
阅读量:3661 次
发布时间:2019-05-21

本文共 2891 字,大约阅读时间需要 9 分钟。

JavaScript-装饰器函数(Decorator)

用于给对象在运行期间动态的增加某个功能,职责等。相较通过继承的方式来扩充对象的功能,装饰器显得更加灵活,首先,我们可以动态给对象选定某个装饰器,而不用hardcore继承对象来实现某个功能点。其次:继承的方式可能会导致子类繁多,仅仅为了增加某一个单一的功能点,显得有些多余了。

下面给出几个常用的装饰器函数示例,相关代码请查看

1 动态添加onload监听函数

function addLoadEvent(fn) {
var oldEvent = window.onload; if(typeof window.onload != 'function') { window.onload = fn; }else { window.onload = function() {
oldEvent(); fn(); }; } } function fn1() {
console.log('onloadFunc 1'); } function fn2() {
console.log('onloadFunc 2'); } function fn3() {
console.log('onloadFunc 3'); } addLoadEvent(fn1); addLoadEvent(fn2); addLoadEvent(fn3);

这里写图片描述

2 前置执行函数和后置执行函数

Function.prototype.before = function(beforfunc) {
var self = this; var outerArgs = Array.prototype.slice.call(arguments, 1); return function() {
var innerArgs = Array.prototype.slice.call(arguments); beforfunc.apply(this, innerArgs); self.apply(this, outerArgs); }; }; Function.prototype.after = function(afterfunc) {
var self = this; var outerArgs = Array.prototype.slice.call(arguments, 1); return function() {
var innerArgs = Array.prototype.slice.call(arguments); self.apply(this, outerArgs); afterfunc.apply(this, innerArgs); }; }; var func = function(name){
console.log('I am ' + name); }; var beforefunc = function(age){
console.log('I am ' + age + ' years old'); }; var afterfunc = function(gender){
console.log('I am a ' + gender); }; var beforeFunc = func.before(beforefunc, 'Andy'); var afterFunc = func.after(afterfunc, 'Andy'); beforeFunc('12'); afterFunc('boy');

执行结果,控制台打印如下:

I am 12 years old
I am Andy
I am Andy
I am a boy

3 函数执行时间计算

function log(func){
return function(...args){
const start = Date.now(); let result = func(...args); const used = Date.now() - start; console.log(`call ${func.name} (${args}) used ${used} ms.`); return result; }; } function calculate(times){
let sum = 0; let i = 1; while(i < times){ sum += i; i++; } return sum; } runCalculate = log(calculate); let result = runCalculate(100000); console.log(result);

注:这里我使用了ES2015(ES6)语法,如果你感兴趣可以查看的博客。

这里写图片描述

当然,装饰器函数不仅仅这些用法。天猫使用的Nodejs框架Koa就基于装饰器函数及ES2015的。希望这篇博客能起到抛砖引玉的作用,使你编写更优雅的JS代码。

你可能感兴趣的文章
建造者模式:
查看>>
适配器模式:
查看>>
LinkedList源码分析
查看>>
美团Java一面面经
查看>>
疏漏总结(九)——http与https
查看>>
疏漏总结(十)
查看>>
线程池
查看>>
servlet的其他作用,git的使用方法
查看>>
Oracle数据库sql*plus常用命令
查看>>
Oracle中表的简单查询
查看>>
Linux-进程管理
查看>>
Linux-ssh服务及服务管理、文件传输
查看>>
Linux-网络配置
查看>>
开发中浏览器兼容的问题总结
查看>>
Vue初体验
查看>>
Vue学习之二(vue指令)
查看>>
人力资源项目-角色模块
查看>>
Matrixport首席执行官葛越晟:区块链市场具有充足的流动性及高溢价
查看>>
量子链创始人帅初:平台和应用需要具备区块链特征,但不一定需要去中心化...
查看>>
印度加密交易所解禁:交易量暴增6倍,全球Buy in了吗?
查看>>