- ES6 教程
- ES6 - 首页
- ES6 - 概述
- ES6 - 环境
- ES6 - 语法
- ES6 - 变量
- ES6 - 运算符
- ES6 - 决策制定
- ES6 - 循环
- ES6 - 函数
- ES6 - 事件
- ES6 - Cookie
- ES6 - 页面重定向
- ES6 - 对话框
- ES6 - void 关键字
- ES6 - 页面打印
- ES6 - 对象
- ES6 - 数字
- ES6 - 布尔值
- ES6 - 字符串
- ES6 - 符号
- ES6 - 新字符串方法
- ES6 - 数组
- ES6 - 日期
- ES6 - 数学
- ES6 - 正则表达式
- ES6 - HTML DOM
- ES6 - 迭代器
- ES6 - 集合
- ES6 - 类
- ES6 - Map 和 Set
- ES6 - Promise
- ES6 - 模块
- ES6 - 错误处理
- ES6 - 对象扩展
- ES6 - 反射 API
- ES6 - 代理 API
- ES6 - 验证
- ES6 - 动画
- ES6 - 多媒体
- ES6 - 调试
- ES6 - 图像映射
- ES6 - 浏览器
- ES7 - 新特性
- ES8 - 新特性
- ES9 - 新特性
- ES6 实用资源
- ES6 - 快速指南
- ES6 - 实用资源
- ES6 - 讨论
ES6 - handler.get()
以下示例定义了一个类 Student,包含构造函数和自定义的 getter 方法 fullName。自定义 getter 方法通过连接 firstName 和 lastName 返回一个新字符串。该程序创建一个代理并定义一个处理对象,该对象在访问 propertiesfirstName、lastName 和 fullName 时进行拦截。属性值将以大写形式返回。
<script> class Student{ constructor(firstName,lastName){ this.firstName = firstName this.lastName = lastName } get fullName(){ return `${this.firstName} : ${this.lastName}` } } const handler = { get: function(target,property){ Reflect.get(target,property).toUpperCase(); } } const s1 = new Student("Tutorials","Point") const proxy = new Proxy(s1,handler) console.log(proxy.fullName) console.log(proxy.firstName) console.log(proxy.lastName) </script>
以上代码的输出如下 −
TUTORIALS : POINT TUTORIALS POINT
广告