ES6 Proxy的应用场景
发布日期:2021-07-23 08:50:53
浏览次数:20
分类:技术文章
本文共 1884 字,大约阅读时间需要 6 分钟。
一、相关API
二、Proxy应用场景
1.数据校验
表单提交的时候做数据校验,例如年龄是不是满足条件,数据类型是不是满足要求等等,这场场景非常适合使用Proxy。
下面展示与业务解耦的校验功能
1)ES6实现方式
{ function validator(target, validator) { return new Proxy(target, { _validator: validator, //set方法用来拦截某个属性的赋值操作,可以接受四个参数,依次为目标对象、属性名、属性值和 Proxy 实例本身,其中最后一个参数可选。 set(target, key, value, proxy) { if (target.hasOwnProperty(key)) { let va = this._validator[key] if (!!va(value)) { return Reflect.set(target, key, value, proxy) } else { throw Error(`不能设置${key}到${value}`) } } else { throw Error(`${key}不存在`) } } }) } const personValidators = { name(val) { return typeof val === 'string' }, age(val) { return typeof val === 'number' && val > 18 } } class Person { constructor(name, age) { this.name = name; this.age = age return validator(this, personValidators) } } const person = new Person('knyel', 30) console.log(person) person.name = 'lk' console.log(person) person.age = 12 console.log(person)}
输出结果为
Proxy {name: "knyel", age: 30}Proxy {name: "lk", age: 30}Uncaught Error: 不能设置age到12 at Object.set (index.js:144) at Object.(index.js:174) at __webpack_require__ (index.js:20) at Object.obj.time (index.js:80) at __webpack_require__ (index.js:20) at Object. (index.js:70) at __webpack_require__ (index.js:20) at index.js:63 at index.js:66
2)ES5实现方式
传统的方式对某个属性进行限制的时候,需要对他进行判断,判断类型是不是合适,是不是满足某种条件,然后才允许它进行修改。
3)对比
用了ES6代理的方式,可以将条件和对象本身(业务逻辑)完全隔离开,后期代码维护中,比如要加一个手机号的验证,我们只需要在修改类Person(添加手机号属性),personValidators(添加手机号验证规则),这样就可以实现了。代码的扩展性、可维护性和健壮性是非常强的。
转载地址:https://blog.csdn.net/namechenfl/article/details/84256583 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
表示我来过!
[***.240.166.169]2024年04月12日 22时33分47秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
跳跃表(Skip list)原理与java实现
2019-04-28
Java 常见的 30 个误区与细节
2019-04-28
干货|基于 Spring Cloud 的微服务落地
2019-04-28
WEB攻击手段及防御第2篇-SQL注入
2019-04-28
WEB攻击手段及防御第3篇-CSRF
2019-04-28
WEB攻击手段及防御-扩展篇
2019-04-28
spring bean初始化及销毁你必须要掌握的回调方法。
2019-04-28
mysql语句性能开销检测profiling详解
2019-04-28
hashCode到底有什么用?
2019-04-28
设计模式之动态代理模式实战
2019-04-28
设计模式之静态代理模式实战
2019-04-28
作为架构师,你必需要搞清楚的概念:POJO、PO、DTO、DAO、BO、VO
2019-04-28
mysql查询优化explain命令详解
2019-04-28
常用加密算法解析
2019-04-28
设计模式之单例模式实践
2019-04-28
彻底理解正向代理和反向代理
2019-04-28
一次频繁Full GC的排查过程,根源居然是它...
2019-04-28
Unicode与UTF-8的区别
2019-04-28
最长回文子串(Longest Palindromic Substring)
2019-04-28
Windows 通过 SecureCRT 8.x 上传文件到Linux服务器
2019-04-28