product/node_modules/is-data-descriptor
Ruikang Zhang e96405c650 Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
..
test Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
.editorconfig Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
.eslintrc Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
.nycrc Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
CHANGELOG.md Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
LICENSE Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
README.md Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
index.js Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00
package.json Merge remote-tracking branch 'product/product' into product 2024-04-14 10:25:28 +08:00

README.md

is-data-descriptor Version Badge

github actions coverage License Downloads

npm badge

Returns true if a value has the characteristics of a valid JavaScript data descriptor.

Install

Install with npm:

$ npm install --save is-data-descriptor

Usage

var isDataDesc = require('is-data-descriptor');
var assert = require('assert');

Examples

true when the descriptor has valid properties with valid values.

// `value` can be anything
assert.equal(isDataDesc({ value: 'foo' }), true);
assert.equal(isDataDesc({ value: function () {} }), true);
assert.equal(isDataDesc({ value: true }), true);

false when not an object

assert.equal(isDataDesc('a'), false);
assert.equal(isDataDesc(null), false);

false when the object has invalid properties

assert.equal(isDataDesc({ value: 'foo', enumerable: 'baz' }), false);
assert.equal(isDataDesc({ value: 'foo', configurable: 'baz' }), false);
assert.equal(isDataDesc({ value: 'foo', get() {} }), false);
assert.equal(isDataDesc({ get() {}, value: 'foo' }), false);

false when a value is not the correct type

assert.equal(isDataDesc({ value: 'foo', enumerable: 'foo' }), false);
assert.equal(isDataDesc({ value: 'foo', configurable: 'foo' }), false);
assert.equal(isDataDesc({ value: 'foo', writable: 'foo' }), false);

Valid properties

The only valid data descriptor properties are the following:

  • configurable (required)
  • enumerable (required)
  • value (optional)
  • writable (optional)

To be a valid data descriptor, either value or writable must be defined.

Invalid properties

A descriptor may have additional invalid properties (an error will not be thrown).

var foo = {};

Object.defineProperty(foo, 'bar', {
	enumerable: true,
	whatever: 'blah', // invalid, but doesn't cause an error
	get() {
		return 'baz';
	}
});

assert.equal(foo.bar, 'baz');

You might also be interested in these projects:

  • is-accessor-descriptor: Returns true if a value has the characteristics of a valid JavaScript accessor descriptor.
  • is-descriptor: Returns true if a value has the characteristics of a valid JavaScript descriptor. Works for… more