Return a property descriptor for an object's own or inherited property.
var propertyDescriptorIn = require( '@stdlib/utils/property-descriptor-in' );
Returns a property descriptor for an object's own or inherited property.
var obj = {
'a': 1,
'b': 2
};
var desc = propertyDescriptorIn( obj, 'a' );
// returns {'configurable':true,'enumerable':true,'writable':true,'value':1}
-
This function differs from the built-in
Object.getOwnPropertyDescriptor()
as follows:- If provided
null
orundefined
, the function returnsnull
, rather than throwing an error. - If an object does not have a provided property, the function returns
null
, rather thanundefined
.
- If provided
var defineProperty = require( '@stdlib/utils/define-property' );
var propertyDescriptorIn = require( '@stdlib/utils/property-descriptor-in' );
function Foo() {
this.beep = 'boop';
this.a = {
'b': 'c'
};
defineProperty( this, 'baz', {
'value': 'qux',
'configurable': true,
'writable': true,
'enumerable': false
});
return this;
}
Foo.prototype.foo = [ 'bar' ];
var obj = new Foo();
var desc = propertyDescriptorIn( obj, 'foo' );
console.log( desc );
// => {'configurable':true,'enumerable':true,'writable':true,'value':['bar']}
@stdlib/assert/has-property
: test if an object has a specified property, either own or inherited.@stdlib/utils/define-property
: define (or modify) an object property.@stdlib/utils/property-descriptor
: return a property descriptor for an object's own property.@stdlib/utils/property-descriptors-in
: return an object's own and inherited property descriptors.