es6相关

本文介绍了ES6中的一些关键特性,包括Json操作、Object.defineProperties、Object.create、Array.prototype.reduce、super关键字的使用、属性遍历、Array.from及其应用场景、Promise对象、for...of循环、call、apply、bind方法以及this指向的规则。通过实例展示了这些特性的用法和注意事项,帮助理解ES6中的核心概念。
摘要由CSDN通过智能技术生成

Json

JSON.parse()

JSON.stringify()


目前,有四个操作会忽略enumerable为false的属性。

for…in循环:只遍历对象自身的和继承的可枚举的属性。

Object.keys():返回对象自身的所有可枚举的属性的键名。

JSON.stringify():只串行化对象自身的可枚举的属性。

Object.assign(): 忽略enumerable为false的属性,只拷贝对象自身的可枚举的属性。

总的来说,操作中引入继承的属性会让问题复杂化,大多数时候,我们只关心对象自身的属性。所以,尽量不要用for…in循环,而用Object.keys()代替。


Object.defineProperties

例:

var obj = {};
Object.defineProperties(obj, {
  'property1': {
    value: true,
    writable: true
  },
  'property2': {
    value: 'Hello',
    writable: false
  }
  // etc. etc.
});

Object.create()

Object.create(proto[, propertiesObject])

参数

proto
新创建对象的原型对象。

propertiesObject
可选。如果没有指定为undefined,则是要添加到新创建对象的可枚举属性(即其自身定义的属性,而不是其原型链上的枚举属性)对象的属性描述符以及相应的属性名称。这些属性对应Object.defineProperties()的第二个参数。

返回值

在指定原型对象上添加新属性后的对象。

var o;

// 创建一个原型为null的空对象
o = Object.create(null);


o = {};
// 以字面量方式创建的空对象就相当于:
o = Object.create(Object.prototype);


o = Object.create(Object.prototype, {
  // foo会成为所创建对象的数据属性
  foo: { 
    writable:true,
    configurable:true,
    value: "hello" 
  },
  // bar会成为所创建对象的访问器属性
  bar: {
    configurable: false,
    get: function() {
    return 10 },
    set: function(value) {
   
      console.log("Setting `o.bar` to", value);
    }
  }
});

Array.prototype.reduce()

不解释,看链接 (。・`ω´・)


浅谈ES6中super关键字

不解释,看链接 (。・`ω´・)


属性的遍历

ES6 一共有 5 种方法可以遍历对象的属性。

(1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值