// 返回数组,成员是参数对象自身的(不含继承的)全部可遍历(enumerable)属性的键名。javascript
eg:var obj = {a:1,b:'gy'} Object.keys(obj) // ['a','b']
//返回 值 数组html
返回数组,成员是参数对象自身的(不含继承的)全部可遍历(enumerable)属性的键值java
eg1:var obj = {a:1,b:'gy'} Object.values(obj) //['a','b'] eg2:var obj = Object.create({},{p:{value:42}}); Object.values(obj) //[] //Oject.create的第二个参数添加的对象属性,若是不显示声明,默认是不可遍历的,因此Object.values不会返回这个属性 eg3:Object.values({[Symbol()]:123,foo:'abc'}) //['abc'] Object.values 会过滤属性名为 Symbol 值得属性 eg4:Object.values('foo') //['f','0','o'] //若是参数不是对象,Object会将其转为对象 eg5:Object.values(42) //[] Object.values(true) //[] //数值和boolean的包装对象 ,都不会成为实例添加非继承的属性
//返回 键值对 数组数组
var obj = {a:'11',b:'name'} Object.entries(obj) //[['a','11'],['b',22]] //用法和Object很是类似
//用对象去(带原型带属性)建立新对象spa
//使用指定的原型对象及其属性去新建一个新的对象 var o = Object.create(Object.prototype,{ foo:{ writable:true, configurable:true, value:'hello' }, bar:{ configurable:false, get:function(){return 10}, set:function(value){ console.log('-----') } } }) console.log(o)
//用来判断一个数组是否包含指定的值,true/falseprototype
arr.includes(searchElement) arr.includes(searchElement,fromIndex)//fromIndex :从该索引处日后查找, (1)至关于indexOf的补充 var arr = ['a','b','c','d','NaN'] arr.incudes('NaN')//true arr.indexOf('NaN') //-1 (2)第二个参数表示判断的起始位置 为负数时:从右面过来第几个,搜索方向仍是从左到右
参考: http://www.cnblogs.com/lmxxlm-123/p/9651579.htmlcode