Math.max 实现得到数组中最大的一项
var array = [1,2,3,4,5]; var max = Math.max.apply(null,array); console.log(max); // 5
调用的时候第一个参数给了一个null,这个是因为没有对象去调用这个方法,只需要用这个方法帮助运算,得到返回的结果就行,所以直接传递了一个null过去。
Math.min 实现得到数组中最小的一项
var min= Math.min.apply(添加max与min方法那就会需要用到原生对象方法
Object.defineProperty()
,会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象Object.defineProperty(Array.prototype,'max'falsetruefunction () { return Math.max.apply(null,this); } }); Object.defineProperty(Array.prototype,'min'return Math.min.apply(); } });直接在数组上调用即可:
var arr = [54,545,2165,56]; console.log(arr.max()); console.log(arr.min());上面讲到了Object.defineProperty的方法,下面我们来理解下。
Object.defineProperty的使用
对象是由多个名/值对组成的无序的集合。对象中每个属性对应任意类型的值。定义对象可以使用构造函数或字面量的形式:
除了以上添加属性的方式,还可以使用
Object.defineProperty
定义新属性或修改原有的属性。Object.defineProperty()描述
语法:
Object.defineProperty(obj,prop,descriptor)
参数说明:
返回值:
传入函数的对象。即第一个参数obj
针对属性,我们可以给这个属性设置一些特性,比如是否只读不可以写;是否可以被
for..in
或Object.keys()
遍历。给对象的属性添加特性描述,目前提供两种形式:数据描述和存取器描述。
数据描述
var obj = { test:"hello" } 对象已有的属性添加特性描述 Object.defineProperty(obj,"test"true | }); 对象新添加的属性的特性描述 Object.defineProperty(obj,"newKey" });value
属性对应的值,可以使任意类型的值,默认为undefined
{} 第一种情况:不设置value属性 Object.defineProperty(obj,{ }); console.log( obj.newKey ); undefined ------------------------------ 第二种情况:设置value属性 Object.defineProperty(obj,{ value:"hello" }); console.log( obj.newKey ); hellowritable
属性的值是否可以被重写。设置为true可以被重写;设置为false,不能被重写。默认为false。
第一种情况:writable设置为false,不能重写。 Object.defineProperty(obj,1)">更改newKey的值 obj.newKey = "change value"; console.log( obj.newKey ); hello 第二种情况:writable设置为true,可以重写 Object.defineProperty(obj,1)">change valueenumerable
此属性是否可以被枚举(使用for...in或Object.keys())。设置为true可以被枚举;设置为false,不能被枚举。默认为false。
第一种情况:enumerable设置为false,不能被枚举。 Object.defineProperty(obj,1)"> }); 枚举对象的属性 for( var attr in obj ){ console.log( attr ); } 第二种情况:enumerable设置为true,可以被枚举。 Object.defineProperty(obj,1)"> obj ){ console.log( attr ); newKey }configurable
是否可以删除目标属性或是否可以再次修改属性的特性(writable,configurable,enumerable)。设置为true可以被删除或可以重新设置特性;设置为false,不能被删除或不可以重新设置特性。默认为false。
这个属性起到两个作用:
-----------------测试目标属性是否能被删除------------------------ 第一种情况:configurable设置为false,不能被删除。 Object.defineProperty(obj,configurable:删除属性 delete obj.newKey; console.log( obj.newKey ); 第二种情况:configurable设置为true,可以被删除。 Object.defineProperty(obj,1)">undefined -----------------测试是否可以再次修改特性------------------------ 第一种情况:configurable设置为false,不能再次修改特性。 Object.defineProperty(obj,1)">重新修改特性 Object.defineProperty(obj,1)"> }); console.log( obj.newKey ); 报错:Uncaught TypeError: Cannot redefine property: newKey 第二种情况:configurable设置为true,可以再次修改特性。 Object.defineProperty(obj,1)">hello定义对象的时候添加的属性,是可删除、可重写、可枚举的。 } 改写值 obj.test = 'change value'; console.log( obj.test ); 'change value' Object.defineProperty(obj,"test" }) 再次改写值 obj.test = 'change value again'依然是:'change value'提示:一旦使用
Object.defineProperty
给对象添加属性,那么如果不设置属性的特性,那么configurable
、enumerable
、writable
这些值都为默认的false
{}; 定义的新属性后,这个属性的特性中configurable,enumerable,writable都为默认的值false //这就导致了newkey这个是不能重写、不能枚举、不能再次设置特性 // Object.defineProperty(obj,'newKey'设置值 obj.newKey = 'hello'; console.log(obj.newKey); 枚举 obj ){ console.log(attr); }设置的特性总结:
存取器描述
{}; Object.defineProperty(obj,"newKey"function (){} | undefined,set:function (value){} | undefined configurable: enumerable: });getter/setter
当设置或获取对象的某个属性的值的时候,可以提供getter/setter方法。
var initValue = 'hello'; Object.defineProperty(obj,1)"> (){ 当获取值的时候触发的函数 return initValue; },1)"> (value){ 当设置值的时候触发的函数,设置的新值通过参数value拿到 initValue = value; } }); 获取值 console.log( obj.newKey ); 设置值 obj.newKey = 'change value'; console.log( obj.newKey ); change value注意:get或set不是必须成对出现,任写其一就可以。如果不设置方法,则get和set的默认值为undefined
通过Object.defineProperty给一个对象的某个属性添加多个方法,如下例子:
(){ var self = ; var num = 0 { add:(value){ return num + value; },reduce:return num - value; } } } }); console.log(obj.atrr.add(5)); 5 console.log(obj.atrr.add(8)); 8 console.log(obj.atrr.reduce(8)); -8说明:在obj对象的atrr对象上添加了两个方法add与reduce.
兼容性
在ie8下只能在DOM对象上使用,尝试在原生的对象使用
Object.defineProperty()
会报错。参考