ES3、ES5、ES6对象代理的写法差异
ES3的对象代理写法:
- console.log('定义私有变量ES3写法:')
- // ES3
- var Person = function (){
- var data = {
- name:'ES3',
- age:14,
- sex:'nv'
- }
- // 读API
- this.get = function(key){
- return data[key]
- }
- // 写API
- this.set = function(key,value){
- if(key !== 'sex'){
- data[key] = value
- }
- }
- }
- // 声明一个实例
- var person = new Person();
- // 读取
console.table({name:person.get('name'),age:person.get('age'),sex:person.get('sex')});- // 修改
- person.set('name','c-ES3') // 修改name为c-ES3
- console.table({name:person.get('name'),age:person.get('age'),sex:person.get('sex')});
- person.set('sex','nan') // 修改sex为nan 修改失败,因为被设置了保护
- console.table({name:person.get('name'),age:person.get('age'),sex:person.get('sex')});
ES5的对象代理写法:
- console.log('定义私有变量ES5写法:')
- // ES5
- var Person = {
- name:'ES5',
- age:14
- }
- // 设置保护,不可被写
- Object.defineProperty(Person,'sex',{
- writable:false,
- value:'nv'
- })
- // 读取
- console.table({
- name:Person.name,
- age:Person.age,
- sex:Person.sex
- })
- // 修改
- Person.name = 'c-ES5' // 修改name为c-ES5
- console.table({
- name:Person.name,
- age:Person.age,
- sex:Person.sex
- })
- Person.sex = 'nan' // 修改sex为nan 修改失败,因为被设置了保护
- console.table({
- name:Person.name,
- age:Person.age,
- sex:Person.sex
- })
ES6的对象代理写法:
- console.log('定义私有变量ES6写法:')
- let Person1 = {
- name:'ES6',
- age:14,
- sex:'nv'
- }
- // 设置对象代理
- let person1 = new Proxy(Person1,{
- // 读
- get(target,key){
- return target[key]
- },
- // 写
- set(target,key,value){
- if(key !== 'sex'){
- target[key] = value
- }
- }
- });
- // 读取
- console.table({
- name:person1.name,
- age:person1.age,
- sex:person1.sex
- })
- // 修改name为c-ES6
- person1.name = 'c-ES6'
- console.table({
- name:person1.name,
- age:person1.age,
- sex:person1.sex
- })
- // 修改sex为nan 修改失败,因为被设置了保护
- person1.sex = 'nan'
- console.table({
- name:person1.name,
- age:person1.age,
- sex:person1.sex
- })
ES3、ES5、ES6对象代理的写法差异的更多相关文章
- ES5和ES6对象导出和导入(转载,待整理)
1.import ... form...替代 require() //不接收对象 require:require('s.css'); //(es5) improt 's.css' //(es6) // ...
- React Native 的ES5 ES6写法对照表
模块 引用 在ES5里,如果使用CommonJS标准,引入React包基本通过require进行,代码类似这样: //ES5 var React = require("react" ...
- React/React Native 的ES5 ES6写法对照表
//es6与es5的区别很多React/React Native的初学者都被ES6的问题迷惑:各路大神都建议我们直接学习ES6的语法(class Foo extends React.Component ...
- React/React Native 的ES5 ES6写法对照表-b
很多React/React Native的初学者都被ES6的问题迷惑:各路大神都建议我们直接学习ES6的语法(class Foo extends React.Component),然而网上搜到的很多教 ...
- 【转】React Native中ES5 ES6写法对照
很多React Native的初学者都被ES6的问题迷惑:各路大神都建议我们直接学习ES6的语法(class Foo extends React.Component),然而网上搜到的很多教程和例子都是 ...
- React Native之ES5/ES6语法差异对照表
很多React/React Native的初学者都被ES6的问题迷惑:各路大神都建议我们直接学习ES6的语法(class Foo extends React.Component),然而网上搜到的很多教 ...
- es6对象内函数的两种写法
es6对象内函数一般有两种写法: var person1 = { name: "p1", sayThis() { console.log(this); } }; var perso ...
- React/React Native的 ES5 ES6 写法对照
ES5 ES6 模块 var React = require("react-native); var { Image, Text, View } = React; import Re ...
- 简述ES5 ES6
很久前的某一天,一位大神问我,你知道ES6相对于ES5有什么改进吗? 我一脸懵逼的反问,那个啥,啥是ES5.ES6啊. 不得不承认与大神之间的差距,回来深思了这个问题,结合以前的知识,算是有了点眉目. ...
随机推荐
- ORACLE关于日志文件基本操作
1.查询系统使用的是哪一组日志文件:SELECT * FROM V$LOG; 2.查询正在使用的组所对应的日志文件:SELECT * FROM V$LOGFILE; 3.强制日志切换:ALTER SY ...
- 【5】Android Service 与 AIDL
前言:本系列仅介绍基本大体的使用步骤,而不对每个步骤进行细致的讲解.读者可作为已经对相关内容有所了解后的快速查阅. 一.单应用内Service的使用 Service组件与Activity以IBinde ...
- 基于阿里云平台的使用python脚本发送短信
第一步:点击短信服务下的帮助文档 第二步:安装python的SDK:点击安装python sdk 第三步:直接通过python的pip工具安装即可,方便快捷: 第四步:点击红框进行测试: 第五步:测试 ...
- 剑指Offer-28.数组中出现次数超过一半的数字(C++/Java)
题目: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2.如 ...
- JVM-Jinfo命令
jinfo JVM Configuration info这个命令作用是实时查看和调整虚拟机运行参数. 之前的jps -v口令只能查看到显示指定的参数,如果想要查看未被显示指定的参数的值就要使用jinf ...
- js 的cookie问题
获取时解码可以用decodeURIComponent(),代替 unescape() // 设置cookiefunction setCookie(name,value) { var Days = 30 ...
- 试着用workerman开发一个在线聊天应用
聊天功能是很常见的一种功能,Workerman是一款开源高性能异步PHP socket即时通讯框架. 什么是Workerman? Workerman是一款 开源 高性能异步 PHP socket即时通 ...
- SqlServer ----- 拷贝数据表
两种方式,第一种方式只是把表中的字段进行拷贝,第二种把表中的关联关系,主键自增长全部拷贝. 1.把表中的关联关系,主键自增长全部拷贝. 选择需要拷贝的表,点击编辑器窗口,会看到这个表的sql 语句,主 ...
- MySQL-8.0.x DDL 原子性
[1.mysql-8.0.x 新特性之 DDL 原子性] 在没有 DDL 原子性之前 DBA 对 DDL 语句基本上是无能为力的,比如说 DDL 执行的过程中停电了,这下就只有天知道了.实现上最终的愿 ...
- PAT 1002 A+B for Polynomials(map模拟)
This time, you are supposed to find A+B where A and B are two polynomials(多项式). Input Each input fil ...