全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript装饰器函数(Decorator)实例详解

本文实例讲述了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小时内与您取得联系。