本文实例讲述了JavaScript装饰器函数(Decorator)。分享给大家供大家参考,具体如下:

装饰器函数(Decorator)用于给对象在运行期间动态的增加某个功能,职责等。相较通过继承的方式来扩充对象的功能,装饰器显得更加灵活,首先,我们可以动态给对象选定某个装饰器,而不用hardcore继承对象来实现某个功能点。其次:继承的方式可能会导致子类繁多,仅仅为了增加某一个单一的功能点,显得有些多余了。
下面给出几个常用的装饰器函数示例,相关代码请查看github。
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)语法,如果你感兴趣可以查看前面关于ES6的相关内容。
当然,装饰器函数不仅仅这些用法。天猫使用的Nodejs框架Koa就基于装饰器函数及ES2015的Generator。希望这篇文章能起到抛砖引玉的作用,使你编写更优雅的JS代码。
更多关于JavaScript相关内容可查看本站专题:《javascript面向对象入门教程》、《JavaScript中json操作技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
# JavaScript
# 装饰器函数
# Decorator
# nuxt框架中路由鉴权之Koa和Session的用法
# es7学习教程之Decorators(修饰器)详解
# 利用Decorator如何控制Koa路由详解
# 相关内容
# 几个
# 如果你
# 子类
# 遍历
# 执行时间
# 感兴趣
# 我们可以
# 抛砖引玉
# 数据结构
# 给大家
# 使你
# 这篇文章
# 更多关于
# 来实现
# 所述
# 程序设计
# 请查看
# 可以查看
# 面向对象
相关文章:
建站ABC备案流程中有哪些关键注意事项?
网站制作公司排行榜,四大门户网站排名?
建站主机默认首页配置指南:核心功能与访问路径优化
建站上市公司网站建设方案与SEO优化服务定制指南
如何选择建站程序?包含哪些必备功能与类型?
Swift中switch语句区间和元组模式匹配
高性价比服务器租赁——企业级配置与24小时运维服务
如何用虚拟主机快速搭建网站?详细步骤解析
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
南平网站制作公司,2025年南平市事业单位报名时间?
香港网站服务器数量如何影响SEO优化效果?
TestNG的testng.xml配置文件怎么写
开心动漫网站制作软件下载,十分开心动画为何停播?
,怎么在广州志愿者网站注册?
香港服务器WordPress建站指南:SEO优化与高效部署策略
文字头像制作网站推荐软件,醒图能自动配文字吗?
网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?
c++怎么用jemalloc c++替换默认内存分配器【性能】
如何用PHP工具快速搭建高效网站?
青岛网站建设如何选择本地服务器?
如何在云主机上快速搭建网站?
公司网站设计制作厂家,怎么创建自己的一个网站?
如何快速搭建响应式可视化网站?
建站之星后台密码如何安全设置与找回?
魔方云NAT建站如何实现端口转发?
阿里云网站制作公司,阿里云快速搭建网站好用吗?
如何在局域网内绑定自建网站域名?
零基础网站服务器架设实战:轻量应用与域名解析配置指南
如何用景安虚拟主机手机版绑定域名建站?
孙琪峥织梦建站教程如何优化数据库安全?
如何在阿里云香港服务器快速搭建网站?
如何通过宝塔面板实现本地网站访问?
SQL查询语句优化的实用方法总结
存储型VPS适合搭建中小型网站吗?
简历在线制作网站免费,免费下载个人简历的网站是哪些?
外贸公司网站制作哪家好,maersk船公司官网?
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
如何在Golang中引入测试模块_Golang测试包导入与使用实践
建站主机选购指南:核心配置与性价比推荐解析
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
如何访问已购建站主机并解决登录问题?
武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?
宝塔新建站点为何无法访问?如何排查?
制作国外网站的软件,国外有哪些比较优质的网站推荐?
高配服务器限时抢购:企业级配置与回收服务一站式优惠方案
如何打造高效商业网站?建站目的决定转化率
如何解决ASP生成WAP建站中文乱码问题?
建站之星收费标准详解:套餐费用及年费价格表一览
手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。