es6的对象新增的方法】的更多相关文章

属性的简洁表示法 ES6 允许在大括号里面直接写入变量和函数,作为对象的属性和方法.这样的书写更加简洁. const foo = 'bar'; const baz = { foo }; console.log(baz); // { foo: 'bar' } function f(name, age) { return { name, age }; } // 等同于 // function f(name, age) { // return { // name: name, // age: age…
Object.is 可以看成是=== 的加强版, 其修正了 === 的 NaN 不等于自身, 以及 +0 等于 -0 另外说下, == 会自动转型, 但是 Object.is 也是如果类型不一致也是不相等的 Object.assign 用于对象的合并, 可以把对象的所有可以枚举属性复制到目标对象(枚举属性包含原型中的属性吗??? )  (=== 只拷贝原对象的自身属性, 不拷贝继承的, 也不拷贝不可枚举的) 如果原对象和目标对象有相同的属性名, 那么原对象会覆盖掉目标对象中的属性值 (这个可以用…
1. Array.from() Array.from方法用于将两类对象转为真正的数组:类数组的对象( array-like object )和可遍历( iterable )的对象(包括 ES6 新增的数据结构 Set 和Map ). let arrayLike = { '0': 'a', '1': 'b', '2': 'c', length: 3 }; // ES5 的写法 var arr1 = [].slice.call(arrayLike); // ['a', 'b', 'c'] // ES…
Math.trunc() Math.trunc方法用于去除一个数的小数部分,返回整数部分. 对于没有部署这个方法的环境,可以用下面的代码模拟. Math.trunc = Math.trunc || function(x) { return x < 0 ? Math.ceil(x) : Math.floor(x); }; Math.sign() Math.sign方法用来判断一个数到底是正数.负数.还是零. 对于没有部署这个方法的环境,可以用下面的代码模拟. Math.sign = Math.si…
ES6给Object拓展了许多新的方法,如: keys(obj):获取对象的所有key形成的数组     var obj = { foo: 'bar', baz: 42 };  Object.keys(obj);  // ["foo", "baz"] values(obj):获取对象的所有value形成的数组 var obj = { foo: 'bar', baz: 42 };  Object.values(obj);  // ["bar", 4…
Array.find((item,indexArr,arr)=>{}) 掌握 找出第一个符合条件的数组成员. 它的参数是一个回调函数,对所有数组成员依次执行该回调函数. 直到找出第一个返回值为true的成员,然后返回该成员. 如果没有符合条件的成员,则返回undefined. -- 找出第一个大于15的数字 let arr = [10, 20, 30] let firstItem = arr.find((item, index, Arr) => { return item > 15 })…
Object.is()-----判断是否全等,和===一样Object.assign()-----对象的复制Object.keys()-----以数组的形式返回所有可遍历属性的键名,原型上的属性不能遍历Object.values()-----以数组的形式返回所有可遍历属性的键值,原型上的属性不能遍历Object.entries()-----以数组的形式返回所有可遍历属性的键值对,原型上的属性不能遍历 var obj1=Object.create(obj)-----将obj的所有属性当做obj1的…
String.prototype.replaceAll = function(reallyDo, replaceWith, ignoreCase) { if(! RegExp.prototype.isPrototypeOf(reallyDo)) { return this.replace(new RegExp(reallyDo,(ignoreCase?"gi":g)),replaceWith); } else { return this.replace(reallyDo, replac…
ES6为对象带来的新特性. 对象传统的写法: let person={ 'name':'Lily', 'say':function(){ alert('hello!'); } } 1.ES6中写法更简便 对象属性: var name='Lily'; var age='13'; var person={name,age}; console.log(person)     //{name:'Lily',age:'13'} 对象方法: var person={ say(){      //省略了fun…
ES6不仅为字符串.数值和数组带来了扩展,也为对象带来了很多新特性.这一节,我们来一起学习一下对象的扩展. 对象的传统表示法 我们回顾一下,对象的传统表示法: let person = { "name":"张三", "say":function(){ alert("你好吗?"); } } 上面的案例很简单,变量person就是一个对象,对象含有name属性和一个say方法.表示法是用键值对的形式来表示,这就是传统的表示法. E…