深入理解ES6之《扩展对象》
属性初始值的简写
当对象字面量只有一个属性的名称时,JS引擎会在可访问作用域中查找其同名变量;如果找到则该变量的值被赋给对象字面量里的同名属性
function createPerson(name, age) {
return {
name,
age
}
}
对象方法的简写
var person = {
name: 'angela',
sayName() {
console.log(this.name)
}
}
可计算属性名
在ES5中如果属性名中包含空格或者是动态的字符串变量作为属性名,则需要用[]方括号来访问,如下所示
var person = {},
lastName = 'last name';
person["first name"] = 'Li'
person[lastName] = 'yun hua'
这种方式适用于属性名提前已经或可被字符串字面量表示的情况,如果属性名“first name”被包含在一个变量中或者需要通过计算才得到该变量的值
ES6支持了可计算属性名
比方说上面的代码ES6可简化写成如下:
let lastName = 'last name';
var person = {
"first name": 'Li',
[lastName]: 'yun hua'
}
甚至方括号中内容同样可以使用表达式作为属性的可计算名称
var suffix = 'name'
var person = {
['first ' + suffix]: 'Li',
['last ' + suffix]: 'yun hua'
}
也就是说任何可用于对象实例括号记法的属性名同样可以作为对象字面量中计算属性名
Object.is
由于全等===有一些特例:1、+0和-0相等 2、NaN和NaN不完全相等
故ES6引用了Object.is方法来弥补全等运算符的不准备运算
对Object.is方法来说,其运算结果大部分情况与===运算符相同,唯一区别在于+0和-0被识别为不相等,NaN和NaN被识别为相等
Object.assign
Object.assign方法接受任意数量的源对象,并按指定的顺序将属性复制到接收对象中,所以如果多个源对象具有同名属性,则排位靠后的源对象会覆盖排位靠前的
有一个需要特别注意的点是Object.assign方法不能将提供者的访问器属性复制到接收对象中,由于Object.assign执行了赋值操作,因此提供者的访问器属性最终会被转变为接收对象中的一个数据属性
var receiver = {},
supplier = {
get name() {
return "file.js"
}
}
Object.assign(receiver, supplier)
var desc = Object.getOwnPropertyDescriptor(receiver, "name")
console.log(desc.value)//file.js
console.log(desc.get)//undefined
重复的对象字面量属性
在ES5严格模式下,对于对象字面量重复属性则会抛出错误
但在ES6严格模式下,不会报错,取值会选取最后一个
'use strict'
var person = {
name: 'lisa',
name: 'angela'
}
console.log(person.name)//angela
自有属性的枚举顺序
所有数字键按升序排序
所有字符串按照它们被加入对象的顺序排序
所有symbol键按照它们被加入对象的顺序排序
var obj = {
a: 1,
0: 1,
c: 1,
2: 1,
b: 1,
1: 1
}
obj.d = 1
console.log(Object.getOwnPropertyNames(obj).join(''))//012acbd
改变对象的原型
ES5中可以通过Object.getPrototypeOf来返回任意指定对象的原型
ES6中添加了Object.setPrototypeOf来改变任意指定对象的原型
var person = {
getGreeting() {
return 'hello'
}
}
var dog = {
getGreeting() {
return 'woof'
}
}
let friend = Object.create(person)
console.log(friend.getGreeting())//hello
console.log(Object.getPrototypeOf(friend) === person)//true
Object.setPrototypeOf(friend, dog)
console.log(friend.getGreeting())//woof
console.log(Object.getPrototypeOf(friend) === dog)//true
简化了原型访问的Super引用
在ES5中如果要调用父类的方法,则一般是通过如果这种方式,也就是获得原型对象再通过call来调用
Object.getPrototypeOf(this).getGreeting.call(this)
var person = {
getGreeting() {
return 'hello'
}
}
var dog = {
getGreeting() {
return 'woof'
}
}
var friend = {
getGreeting() {
return Object.getPrototypeOf(this).getGreeting.call(this) + ",hi!";
}
}
Object.setPrototypeOf(friend, person)
console.log(friend.getGreeting())//hello,hi!
console.log(Object.getPrototypeOf(friend) === person)//true
Object.setPrototypeOf(friend,dog)
console.log(friend.getGreeting())//woof,hi!
console.log(Object.getPrototypeOf(friend) === dog)//true
但是在多重继承的情况下,上述方法则会出错,举例来说
var person = {
getGreeting() {
return 'hello'
}
}
var friend = {
getGreeting() {
return Object.getPrototypeOf(this).getGreeting.call(this) + ",hi!";
}
}
Object.setPrototypeOf(friend, person)
var relative = Object.create(friend)
console.log(person.getGreeting())//hello
console.log(friend.getGreeting())//hello,hi!
console.log(relative.getGreeting())// 报错 Uncaught RangeError: Maximum call stack size exceeded
ES6中通过super关键字可轻松解决问题
var person = {
getGreeting() {
return 'hello'
}
}
var friend = {
getGreeting() {
return super.getGreeting.call(this) + ",hi!";
}
}
Object.setPrototypeOf(friend, person)
var relative = Object.create(friend)
console.log(person.getGreeting())//hello
console.log(friend.getGreeting())//hello,hi!
console.log(relative.getGreeting())// hello,hi
大家可能会疑惑super是怎么做到知道真正的调用对象是哪个
这其实是因为ES6中正式将方法定义为一个函数,它会有一个内部的[[HomeObject]]属性来容纳这个方法从属的对象
var person = {
// 是方法
getGreeting() {
return 'hello'
}
}
function shareGreeting(params) {
return 'Hi!'
}
person.getGreeting方法的[[HomeObject]]属性为person,而shareGreeting函数未将其赋值给一个对象,因而没有明确定义其[[HomeObject]]属性
super的所有引用都通过[[HomeObject]]属性来确定后续的运行过程
在[[HomeObject]]属性上调用Object.getPrototypeOf方法来检索原型的引用
搜索原型找以同名函数
设置this绑定并调用相应的方法
深入理解ES6之《扩展对象》的更多相关文章
- 《深入理解ES6》笔记——扩展对象的功能性(4)
变量功能被加强了.函数功能被加强了,那么作为JavaScript中最普遍的对象,不加强对得起观众吗? 对象类别 在ES6中,对象分为下面几种叫法.(不需要知道概念) 1.普通对象 2.特异对象 3.标 ...
- 深入理解 ES6中的 Reflect
阅读目录 一:Reflect.get(target, name, receiver) 二:Reflect.set(target,name,value,receiver) 三:Reflect.apply ...
- ES6的promise对象研究
ES6的promise对象研究 什么叫promise? Promise对象可以理解为一次执行的异步操作,使用promise对象之后可以使用一种链式调用的方式来组织代码:让代码更加的直观. 那我们为什么 ...
- ES6正则表达式扩展
前面的话 正则表达式是javascript操作字符串的一个重要组成部分,但在以往的版本中并未有太多改变.然而,在ES6中,随着字符串操作的变更, ES6也对正则表达式进行了一些更新.本文将详细介绍ES ...
- ES6函数扩展
前面的话 函数是所有编程语言的重要组成部分,在ES6出现前,JS的函数语法一直没有太大的变化,从而遗留了很多问题和的做法,导致实现一些基本的功能经常要编写很多代码.ES6大力度地更新了函数特性,在ES ...
- ES6数组扩展
前面的话 数组是一种基础的JS对象,随着时间推进,JS中的其他部分一直在演进,而直到ES5标准才为数组对象引入一些新方法来简化使用.ES6标准继续改进数组,添加了很多新功能.本文将详细介绍ES6数组扩 ...
- ES6数字扩展
前面的话 本文将详细介绍ES6数字扩展 指数运算符 ES2016引入的唯一一个JS语法变化是求幂运算符,它是一种将指数应用于基数的数学运算.JS已有的Math.pow()方法可以执行求幂运算,但它也是 ...
- ES6,扩展运算符的用途
ES6的扩展运算符可以说是非常使用的,在给多参数函数传参,替代Apply,合并数组,和解构配合进行赋值方面提供了很好的便利性. 扩展运算符就是三个点“...”,就是将实现了Iterator 接口的对象 ...
- 理解 ES6 Generator-next()方法
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 前端知识体系:JavaScript基础-原型和原型链-理解 es6 中class构造以及继承的底层实现原理
理解 es6 中class构造以及继承的底层实现原理 原文链接:https://blog.csdn.net/qq_34149805/article/details/86105123 1.ES6 cla ...
随机推荐
- Python:collections.Counter
collections是Python内建的一个集合模块,其中提供了许多有用的集合类: namedtuple:只有属性的简易类 deque:双向增删的List ChainMap:多个字典的链接 Coun ...
- pyqt(三)
六.按钮控件 QPushButton 常见的按钮实现类包括:QPushButton.QRadioButton和QCheckBox QPushButton是最普通的按钮控件,可以响应一些用户的事件 fr ...
- CNN(卷积神经网络)入门
参考博文: 深度学习基础--卷积--1*1的卷积核与全连接的区别:https://blog.csdn.net/wydbyxr/article/details/84061410 如何理解卷积神经网络中的 ...
- SQL Server--一个存储过程对同一个字段执行两种Update
需求: 服务器程序被界面点击"置零"按钮后,所有未完成的任务的状态都置为异常结束. 但分两种情况: 0<=Status<40状态为未完成的任务1,其异常结束状态为50 ...
- 基于idea做java程序的本地k8s调试-skaffold(二)
上一篇讲完了java代码发到本机minikube中run,这篇来讲讲minkube中进行debug(idea下) 话说,上篇是把pigx基础infra微服务都发到了minikube中,这些微服务是ru ...
- call、apply 和 bind
call().apply().bind() 都是用来重定义 this 这个对象的! var obj1 = { username: "HuiTaiLang", fn: functio ...
- mysql全量备份与增量备份
mysql全量备份与增量备份 1.全量备份 全量备份就是把数据库中所有的数据进行备份. 备份所有库: mysqldump -uroot -p456 -S /data/3306/mysql.sock ...
- Java编程学习笔记(基础篇)
一.Java中的数据类型 1.基本数据类型:四类 八种 byte(1) boolean(1) short(2) char(2) int(4) float(4) long(8) double(8) 2. ...
- web自动化之selenium(四)元素等待
隐式等待 说明 隐式等待是通过设置一定时长的等待,让页面上的某些元素能过加载出来,如果超过了设置的时间还没有加载出来则抛出(NoSuchelementException异常),默认单位为"秒 ...
- 2022 年了,还不了解 PWA ? 教你 VuePress 博客如何快速兼容 PWA
前言 在 <一篇带你用 VuePress + Github Pages 搭建博客>中,我们使用 VuePress 搭建了一个博客,最终的效果查看:TypeScript 中文文档. 本篇我们 ...