对象扩展:

1、Object.is(A,B) :比较两个值是否相等,取代===运算;只要值相等代表相等;其中NAN和NAN相等;+0和-0不相等;

2、Object.assign(target,source1,source2.......) :合并源对象的所有可枚举属性到目标对象;同名属性后覆盖前;just one obj,return this obj;【仅一个参数】将源目标非对象先转化为对象,无法转化的将会报错undefined;null;【多个参数】不在首参数为数值、字符串、布尔值、undefined、null均不会复制;只拷贝源对象的自身属性,不拷贝继承属性;【浅拷贝】

注意⚠️:Object.assign处理数组,相同下标的元素后者覆盖前者

    对于取值函数的合并,会先求取值之后合并;取值函数get foo(){return 1} -> foo:1

    es6规定:class的原型均为不可枚举

使用:

/**
* 为对象添加属性
*/
class Untils {
constructor(x, y) {
Object.assign(this, x, y) // 通过Object.assign方法将x,y添加到Untils的实例上
}
}
/**
* 为对象添加方法
*/
Object.assign(someClass.prototype, {
method(x, y) {},
anotherMethod() {}
})
/**
* 克隆对象
*/
function clone(origin) {
return Object.assign({}, origin)
}
/**
* 合并多个对象
*/
(target, ...source) => Object.assign(target, ...source)
/**
* 为属性指定默认值
*/
const defaultOpts = {
level: 3,
color: red
}
function addOpts (opt) {
return Object.assign({},defaultOpts,opt) // defaultOpts引用类型有问题
}
3、Object.keys 遍历对象可枚举的属性的键名,返回数组;不含继承的属性、不含symbol属性【es5】取代for...in
4、Object.values 遍历对象可枚举的属性的键值,返回数组;不含继承的属性、不含symbol属性 配合for...of使用
5、Object.entries 遍历对象可枚举的属性的键值对,返回数组;不含继承的属性、含symbol属性的将忽略当前键值对 配合for...of使用
6、Object.getOwnPropertyDescriptor方法是为了解决Object.assign对get set函数的拷贝值问题,set get无return的情况下,Object.assign拷贝的值为undefined
7、Object.defineProperties(obj,objProperty,DescriptorObj) 修改对象属性默认特性【数据属性】的特定方法【es5】obj属性所在对象,属性名称,属性的描述符对象
8、Object.setPrototypeOf 取代_proto_对原型的处理【写】
9、Object.getPrototypeOf 取代_proto_对原型的处理【读】
10、Object.create 取代_proto_对原型的处理【生成操作】方法创建一个新对象,使用现有的对象来提供新创建的对象的__proto__Object.create({},obj)第二个obj是添加到新创建对象上面的可枚举属性,同时可配置描述符对象 详细可点击此链接查看https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/create
11、super指向当前对象的prototype对象,只能用于对象的方法之中而不能用于对象方法的赋值操作【待总结继承时详述】
解构赋值:要求等号右边为对象,不能为undefined/null,解构赋值的参数需作为最后一位参数;对复合类型仅作为引用;
扩展运算符: ... 相当于Object.assign 取出参数对象的所有可遍历属性拷贝到当前对象之中;
12、Object.hasOwnProperty 用于判断属性是来自对象本身,而不是通过继承自原型链

对象的内部属性:这些特性是为了实现javascript引擎

Descriptor:描述对象【每个对象都有】通过Object.getOwnPropertyDescriptor(obj,'someProperty') 访问

数据属性:如下【还有一种是防问器属性】

enumerable: false 不可枚举

configurable: true 属性修改,可delete,修改为false之后无法再改变此描述符,再次修改 static mode会报错

writable:true 修改属性值
value 读取/写入新值 默认undefined

[[PrimitiveValue]] :原始值

_proto_ 用来读取及设置当前属性的prototype对象【IE11】在无法使用的内部属性时,es6提供了可供使用的对prototype的操作方法以上6、7、8

es6之Object扩展及内部属性的总结的更多相关文章

  1. js--对象内部属性与 Object.defineProperty()

    前言 JavaScript 中允许使用一些内部特性来描述属性的特征,本文来总结一下对象内部属性与 Object.defineProperty() 的相关知识. 正文 1.属性类型 js中使用某些内部属 ...

  2. ES6 函数的扩展2

    8.2 rest参数 ES6引入rest参数(形式为"-变量名"),用于获取函数的多余参数,这样就不需要使用arguments对象了. arguments对象并没有数组的方法,re ...

  3. ES6 之 Object 的方法总结

    阅读:Object 1.obj的"." 或 "[]"方法 读取对象的属性或方法 对象属性的读取:ES6中被Proxy的get(target, propKey, ...

  4. JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

  5. 数组的复制及ES6数组的扩展

    一.数组的复制 // alert([1,2,3]==[1,2,3]); let cc = [0,1,2]; let dd = cc; alert(dd==cc);//此时改变dd会影响cc ES5 只 ...

  6. es6对象的扩展

    对象(object)是 JavaScript 最重要的数据结构之一. object 在es6中新增了很多便利的方法 在es6中允许直接写入变量和方法的名称直接作为对象的属性 let x =1 ,y=2 ...

  7. es6数组的扩展

    数组扩展运算符 ...(三个点) const demoArr=[0,1,2,3,4] console.log(...demoArr) // 0 1 2 3 4 // 他把一个数组用逗号分隔了出来 // ...

  8. ES6中Object.assign() 方法

    ES6中Object.assign() 方法 1. 对象合并Object.assign 方法用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象上.如下代码演示: var targ ...

  9. es6 学习小记 扩展运算符 三个点(...)

    参考: es6 扩展运算符 三个点(...) 经常回顾,方能真正掌握. 一.含义 扩展运算符( spread )是三个点(...).它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列. ...

随机推荐

  1. 策略模式(Strategy

    Strategy 无论什么程序,其目的都是解决问题.而为了解决问题,我们又需要编写特定的算法.使用Strategy模式可以整体地替换算法的实现部分.能够整体地替换算法,能让我们轻松地以不同的算法去解决 ...

  2. 【手撸一个ORM】MyOrm的使用说明

    [手撸一个ORM]第一步.约定和实体描述 [手撸一个ORM]第二步.封装实体描述和实体属性描述 [手撸一个ORM]第三步.SQL语句构造器和SqlParameter封装 [手撸一个ORM]第四步.Ex ...

  3. excel单元格内容合并

    这几天在整理数据,有时候数据都在表格的不同单元格中,想把两格内容合并为一格,于是验证了两种方法 方法一: (1)在B1输入公式=A1&B1 (2)做完第一步后,选中B1后,鼠标移到单元格右下出 ...

  4. 021 Merge Two Sorted Lists 合并两个有序链表

    Merge two sorted linked lists and return it as a new list. The new list should be made by splicing t ...

  5. vector的学习

    学习链接:http://www.runoob.com/cplusplus/cpp-stl-tutorial.html kandaima #include<iostream> #includ ...

  6. vnc安装问题

    在xenserver中安装vncserver软件.启动显示正常 用grep命令查看也确实有线程在运行. 但实际上用命令service vncserver status查看vnc状态,显示没有桌面在运行 ...

  7. Unity C# 调用SaveFileDialog保存Excel文件

    本文原创,转载请注明出处:http://www.cnblogs.com/AdvancePikachu/p/6893934.html 本文学习如何把数据转存为Excel文件并调用SaveFileDial ...

  8. personalWebsite_1:历史记录汇总

    最开始,根据  https://blog.csdn.net/zbl1146556298/article/details/79714239 进行网站构思设计,根据源码, 1.把gradle项目转为mav ...

  9. 几百道常见Java初中级面试题

     注:  有的面试题是我面试的时候遇到的,有的是偶然看见的,还有的是朋友提供的, 稍作整理,以供参考.大部分的应该都是这些了,包含了基础,以及相对深入一点点的东西.   JAVA面试题集 基础知识: ...

  10. GITHUB中GIT BASH基础命令行

    PS:转自https://www.cnblogs.com/WangXinPeng/p/8016293.html 1.常用命令行工具: ①cmd     ②powershell      ③git ba ...