简单理解 ES7 Decorator(装饰器)
如何使用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(装饰器)的更多相关文章
- 装饰器模式&&ES7 Decorator 装饰器
		
装饰器模式(Decorator Pattern)允许向一个现有的对象动态添加新的功能,同时又不改变其结构.相比JavaScript中通过鸡肋的继承来给对象增加功能来说,装饰器模式相比生成子类更为灵活. ...
 - 谈谈Python中的decorator装饰器,如何更优雅的重用代码
		
众所周知,Python本身有很多优雅的语法,让你能用一行代码写出其他语言很多行代码才能做的事情,比如: 最常用的迭代(eg: for i in range(1,10)), 列表生成式(eg: [ x* ...
 - 简单理解Struts2中拦截器与过滤器的区别及执行顺序
		
简单理解Struts2中拦截器与过滤器的区别及执行顺序 当接收到一个httprequest , a) 当外部的httpservletrequest到来时 b) 初始到了servlet容器 传递给一个标 ...
 - 理解Python的装饰器
		
看Flask文档时候看到关于cache的装饰器,有这么一段代码: def cached(timeout=5 * 60, key=’view/%s’): def decorator(f): @wraps ...
 - Python的程序结构[8] -> 装饰器/Decorator -> 装饰器浅析
		
装饰器 / Decorator 目录 关于闭包 装饰器的本质 语法糖 装饰器传入参数 1 关于闭包 / About Closure 装饰器其本质是一个闭包函数,为此首先理解闭包的含义. 闭包(Clos ...
 - Python进阶之decorator装饰器
		
decorator装饰器 .note-content {font-family: "Helvetica Neue",Arial,"Hiragino Sans GB&quo ...
 - koa2使用es7 的装饰器decorator
		
本文主要讲述我在做项目中使用装饰器(decorator)来动态加载koa-router的路由的一个基础架构. 目前JavaScript 对decorator 是不支持,但是可以用babel 来编译 既 ...
 - Decorator装饰器模式个人理解
		
对于装饰器模式,其主要是为了:在不改变本体特征的情况下,对其进行包装.装饰,目的是为了补充.扩展.增强其功能. 有三个原则: 不能改变本体的特征 要对本体的功能进行扩展 装饰器脱离了本体则没有任何含义 ...
 - 项目解析1、登录验证用户是否存在     储备知识   Python 之 decorator装饰器
		
下面是我对 装饰器 这一小节的总结, 以及自己的理解. 注:[本文中的代码参考上述教程] 很多时候我会把Python的很多语法与C++相融合,在C++中,函数的名称即为函数的地址,我们可以通过定义成为 ...
 
随机推荐
- selenium - 下拉框操作
			
# 9. 下拉框操作# (1)等待下拉列表和下拉列表中值存在# (2)在下拉列表中选择一个值 # 三种方式# A. 获取所有的下拉列表值,然后用循环去匹配相同的值 select_by_index(下标 ...
 - Map容器——HashMap及常用API,及put,get方法解析,哈希码的产生和使用
			
Map接口 ① 映射(map)是一个存储键/值对的对象.给定一个键,可以查询到它的值,键和值都是对象; ② 键必须是唯一的,值可以重复; ③ 有些映射可以接收null键和null值,而有的 ...
 - 2016湖南省赛----A 2016 (同余定理)
			
2016湖南省赛----A 2016 (同余定理) Description 给出正整数 n 和 m,统计满足以下条件的正整数对 (a,b) 的数量: 1. 1≤a≤n,1≤b≤m; 2. a×b 是 ...
 - 剑指offer 面试题38
			
面试题38:数字在排序数组中出现的次数 题目:统计一个数字在排序数组中出现的次数.例如输入排序数组{1,2,3,3,3,3,4,5}和数字3,由于3在这个数组中出现了4次,因此输出4. 主要的思路是进 ...
 - Unity3D - UGUI的初级应用
			
添加字体: 把下载好的字体拖拽到Project面板中 - 点击Text组件中Text属性后面的圆点 - 选择刚刚拖拽的字体即可. 创建ToggleGroup(开关组): 1.在Canvas下创建两个T ...
 - iOS学习笔记02-UIScrollView
			
父类UIView方法 // autoresizingMask - 现在基本弃用,改用autoLayout typedef NS_OPTIONS(NSUInteger, UIViewAutoresizi ...
 - poj3311Hie with the Pie
			
Hie with the Pie Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 7599 Accepted: 4088 ...
 - one day php. alomost all;
			
<? namespace Test; use \PhpProject\PhpApp as Other; $u=new Other("ns test"); echo $u-&g ...
 - kafka优化–JVM参数配置优化
			
https://blog.csdn.net/u013063153/article/details/73826403
 - Stockbroker Grapevine(最短路)
			
poj——1125 Stockbroker Grapevine Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 36112 ...