如何使用ES7 Decorator给你的游戏人物开挂?

// 预告: 本文有点小难度,对js不太熟的人可能比较懵逼
// 本文的目的是让你们知其然
// ==========================================
// 今天我们来说一说 es7的 装饰者模式(Decorator)
// 啥是装饰者模式,听着很高大上
// 我不和你扯什么设计模式,元编程,我从一个游戏的例子给大家讲解
// 装饰器就是给一个游戏玩家装饰上了一件牛逼的装备
// ES7 如何使用Decorator强化你的装备 // 1. 一个普通的玩家类,具有攻击力和防御力两项属性
class 玩家 {
// 默认 1点攻击,1点防御
constructor(攻击力 = 1, 防御力 = 1) {
this.init(攻击力, 防御力)
} // 初始化攻击力 防御力
init(攻击力, 防御力) {
this.攻击力 = 攻击力
this.防御力 = 防御力
}
print() {
console.log(`玩家 ==> 攻击力:${this.攻击力}, 防御力:${this.防御力}`)
}
} let player1 = new 玩家() // 创建一个玩家实例
player1.print() // '玩家 ==> 攻击力:1, 防御力:1' // 2. 这一步厉害了
// 我们创建一个方天画戟的装饰器,一出生自动加100攻击力
// 装饰器接受三个固定参数, (目标,属性,属性描述)
function 方天画戟(target, prop, descriptor) {
let func = descriptor.value // 获取目标的init方法
descriptor.value = function() {
// arguments[0]即第一个参数 => 攻击力
arguments[0] += 100 // 攻击力+100
return func.apply(target, arguments) // init(100, 1)
}
return descriptor // 知道为什么要返回它么
} // 升级版玩家,出生自带方天画戟
class 玩家2 {
constructor(攻击力 = 1, 防御力 = 1) {
this.init(攻击力, 防御力)
} // 在init初始化方法上写上 '@装饰器名称' 就把外挂加上了
// 另外装饰器是可以叠加的
// @马云 艾特一下马云,让你更有钱
// 这下子牛逼了
@方天画戟
init(攻击力, 防御力) {
this.攻击力 = 攻击力
this.防御力 = 防御力
}
print() {
console.log(`玩家 ==> 攻击力:${this.攻击力}, 防御力:${this.防御力}`)
}
} let player2 = new 玩家2() // 升级版玩家
player2.print() // '玩家 ==> 攻击力:101, 防御力:1' // 目前Decorator特性还没有任何浏览器支持
// 本文的代码需要使用babel编译之后才会看到结果 // *题外话*,如果你想知道Decorator是干什么的,本文可以帮助您理解
// 如果你想彻底搞懂Decorator,你还需要了解Object.defineProperty
// Object.defineProperty很强大,前端同学常用的vue就是基于此做的数据响应式
// 熟悉Java Python的同学对Decorator应该早已很熟悉了,强大的AOP,数据映射等等 // 本文完

转载:https://zhuanlan.zhihu.com/p/29712462

简单理解 ES7 Decorator(装饰器)的更多相关文章

  1. 装饰器模式&&ES7 Decorator 装饰器

    装饰器模式(Decorator Pattern)允许向一个现有的对象动态添加新的功能,同时又不改变其结构.相比JavaScript中通过鸡肋的继承来给对象增加功能来说,装饰器模式相比生成子类更为灵活. ...

  2. 谈谈Python中的decorator装饰器,如何更优雅的重用代码

    众所周知,Python本身有很多优雅的语法,让你能用一行代码写出其他语言很多行代码才能做的事情,比如: 最常用的迭代(eg: for i in range(1,10)), 列表生成式(eg: [ x* ...

  3. 简单理解Struts2中拦截器与过滤器的区别及执行顺序

    简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...

  4. 理解Python的装饰器

    看Flask文档时候看到关于cache的装饰器,有这么一段代码: def cached(timeout=5 * 60, key=’view/%s’): def decorator(f): @wraps ...

  5. Python的程序结构[8] -> 装饰器/Decorator -> 装饰器浅析

    装饰器 / Decorator 目录 关于闭包 装饰器的本质 语法糖 装饰器传入参数 1 关于闭包 / About Closure 装饰器其本质是一个闭包函数,为此首先理解闭包的含义. 闭包(Clos ...

  6. Python进阶之decorator装饰器

    decorator装饰器 .note-content {font-family: "Helvetica Neue",Arial,"Hiragino Sans GB&quo ...

  7. koa2使用es7 的装饰器decorator

    本文主要讲述我在做项目中使用装饰器(decorator)来动态加载koa-router的路由的一个基础架构. 目前JavaScript 对decorator 是不支持,但是可以用babel 来编译 既 ...

  8. Decorator装饰器模式个人理解

    对于装饰器模式,其主要是为了:在不改变本体特征的情况下,对其进行包装.装饰,目的是为了补充.扩展.增强其功能. 有三个原则: 不能改变本体的特征 要对本体的功能进行扩展 装饰器脱离了本体则没有任何含义 ...

  9. 项目解析1、登录验证用户是否存在 储备知识 Python 之 decorator装饰器

    下面是我对 装饰器 这一小节的总结, 以及自己的理解. 注:[本文中的代码参考上述教程] 很多时候我会把Python的很多语法与C++相融合,在C++中,函数的名称即为函数的地址,我们可以通过定义成为 ...

随机推荐

  1. 使mysql的表内容可以输入中文内容

    修改数据库的字符集mysql>use mydb mysql>alter database mydb character set utf8;

  2. getattr、setattr、hasattr

    写一个演示类 class test(): title="验证getattr.setattr.hasattr方法" def run(self): return "run方法 ...

  3. linux shell脚本监控进程是否存在

    用shell脚本监控进程是否存在 不存在则启动的实例,先上代码干货:    #!/bin/shps -fe|grep processString |grep -v grepif [ $? -ne 0 ...

  4. bootstrap 中dropmenu不起作用

    今天在使用bootstrap发现dropmenu一直不起作用,代码是从官网拷贝过来. 网上查找可以用的页面进行一点点的去除分析,发现竟然是顺序反了导致的. 在使用dropmenu时需要引入jquery ...

  5. Docker网络基础:快速指南

    Docker网络基础:快速指南 原文连接:http://blogxinxiucan.sh1.newtouch.com/2017/07/30/Docker网络基础:快速指南/ 了解有关扩展网络功能的默认 ...

  6. rest-framwork官方文档教程(一)

    该项目是按照官网quickstart进行的,具体也可查看rest-framework官网: https://www.django-rest-framework.org/tutorial/quickst ...

  7. [BZOJ4260] Codechef REBXOR (01字典树,异或前缀和)

    Description Input 输入数据的第一行包含一个整数N,表示数组中的元素个数. 第二行包含N个整数A1,A2,-,AN. Output 输出一行包含给定表达式可能的最大值. Sample ...

  8. APIO2018 题解

    坑了好久,补一补. 话说我当时去参加 $APIO2018$ 了,不过纯粹打铁…… 我的程序交道人家毛子的网站上, $c++14$ 编译器不停地给我编 $RE$,只记得好像是结构体排序的问题(删掉那个排 ...

  9. [转] Makefile 基础 (7) —— Makefile 中 make 的运行

    该篇文章为转载,是对原作者系列文章的总汇加上标注. 支持原创,请移步陈浩大神博客:(最原始版本) http://blog.csdn.net/haoel/article/details/2886 我转自 ...

  10. greenplum /postgres 登陆以及创建修改用户密码

    1.greenplum 启动 bin目录下的gpstart  ,-m为只启动master 2.greenplum 启动之后,通过postgresql登陆 登陆命令:PGOPTIONS="-c ...