[e29cc2e] | 1 | # is-data-descriptor [![NPM version](https://img.shields.io/npm/v/is-data-descriptor.svg?style=flat)](https://www.npmjs.com/package/is-data-descriptor) [![NPM monthly downloads](https://img.shields.io/npm/dm/is-data-descriptor.svg?style=flat)](https://npmjs.org/package/is-data-descriptor) [![NPM total downloads](https://img.shields.io/npm/dt/is-data-descriptor.svg?style=flat)](https://npmjs.org/package/is-data-descriptor) [![Linux Build Status](https://img.shields.io/travis/jonschlinkert/is-data-descriptor.svg?style=flat&label=Travis)](https://travis-ci.org/jonschlinkert/is-data-descriptor)
|
---|
[6a3a178] | 2 |
|
---|
[e29cc2e] | 3 | > Returns true if a value has the characteristics of a valid JavaScript data descriptor.
|
---|
| 4 |
|
---|
| 5 | Please consider following this project's author, [Jon Schlinkert](https://github.com/jonschlinkert), and consider starring the project to show your :heart: and support.
|
---|
[6a3a178] | 6 |
|
---|
| 7 | ## Install
|
---|
| 8 |
|
---|
| 9 | Install with [npm](https://www.npmjs.com/):
|
---|
| 10 |
|
---|
| 11 | ```sh
|
---|
[e29cc2e] | 12 | $ npm install --save is-data-descriptor
|
---|
[6a3a178] | 13 | ```
|
---|
| 14 |
|
---|
| 15 | ## Usage
|
---|
| 16 |
|
---|
| 17 | ```js
|
---|
[e29cc2e] | 18 | var isDataDesc = require('is-data-descriptor');
|
---|
[6a3a178] | 19 | ```
|
---|
| 20 |
|
---|
[e29cc2e] | 21 | ## Examples
|
---|
[6a3a178] | 22 |
|
---|
[e29cc2e] | 23 | `true` when the descriptor has valid properties with valid values.
|
---|
[6a3a178] | 24 |
|
---|
[e29cc2e] | 25 | ```js
|
---|
| 26 | // `value` can be anything
|
---|
| 27 | isDataDesc({value: 'foo'})
|
---|
| 28 | isDataDesc({value: function() {}})
|
---|
| 29 | isDataDesc({value: true})
|
---|
[6a3a178] | 30 | //=> true
|
---|
| 31 | ```
|
---|
| 32 |
|
---|
| 33 | `false` when not an object
|
---|
| 34 |
|
---|
| 35 | ```js
|
---|
[e29cc2e] | 36 | isDataDesc('a')
|
---|
[6a3a178] | 37 | //=> false
|
---|
[e29cc2e] | 38 | isDataDesc(null)
|
---|
[6a3a178] | 39 | //=> false
|
---|
[e29cc2e] | 40 | isDataDesc([])
|
---|
[6a3a178] | 41 | //=> false
|
---|
| 42 | ```
|
---|
| 43 |
|
---|
| 44 | `false` when the object has invalid properties
|
---|
| 45 |
|
---|
| 46 | ```js
|
---|
[e29cc2e] | 47 | isDataDesc({value: 'foo', bar: 'baz'})
|
---|
[6a3a178] | 48 | //=> false
|
---|
[e29cc2e] | 49 | isDataDesc({value: 'foo', bar: 'baz'})
|
---|
[6a3a178] | 50 | //=> false
|
---|
[e29cc2e] | 51 | isDataDesc({value: 'foo', get: function(){}})
|
---|
[6a3a178] | 52 | //=> false
|
---|
[e29cc2e] | 53 | isDataDesc({get: function(){}, value: 'foo'})
|
---|
[6a3a178] | 54 | //=> false
|
---|
| 55 | ```
|
---|
| 56 |
|
---|
| 57 | `false` when a value is not the correct type
|
---|
| 58 |
|
---|
| 59 | ```js
|
---|
[e29cc2e] | 60 | isDataDesc({value: 'foo', enumerable: 'foo'})
|
---|
[6a3a178] | 61 | //=> false
|
---|
[e29cc2e] | 62 | isDataDesc({value: 'foo', configurable: 'foo'})
|
---|
[6a3a178] | 63 | //=> false
|
---|
[e29cc2e] | 64 | isDataDesc({value: 'foo', writable: 'foo'})
|
---|
[6a3a178] | 65 | //=> false
|
---|
| 66 | ```
|
---|
| 67 |
|
---|
[e29cc2e] | 68 | ## Valid properties
|
---|
[6a3a178] | 69 |
|
---|
[e29cc2e] | 70 | The only valid data descriptor properties are the following:
|
---|
[6a3a178] | 71 |
|
---|
[e29cc2e] | 72 | * `configurable` (required)
|
---|
| 73 | * `enumerable` (required)
|
---|
| 74 | * `value` (optional)
|
---|
| 75 | * `writable` (optional)
|
---|
[6a3a178] | 76 |
|
---|
[e29cc2e] | 77 | To be a valid data descriptor, either `value` or `writable` must be defined.
|
---|
[6a3a178] | 78 |
|
---|
[e29cc2e] | 79 | **Invalid properties**
|
---|
[6a3a178] | 80 |
|
---|
[e29cc2e] | 81 | A descriptor may have additional _invalid_ properties (an error will **not** be thrown).
|
---|
[6a3a178] | 82 |
|
---|
| 83 | ```js
|
---|
[e29cc2e] | 84 | var foo = {};
|
---|
| 85 |
|
---|
| 86 | Object.defineProperty(foo, 'bar', {
|
---|
| 87 | enumerable: true,
|
---|
| 88 | whatever: 'blah', // invalid, but doesn't cause an error
|
---|
| 89 | get: function() {
|
---|
| 90 | return 'baz';
|
---|
| 91 | }
|
---|
| 92 | });
|
---|
[6a3a178] | 93 |
|
---|
[e29cc2e] | 94 | console.log(foo.bar);
|
---|
| 95 | //=> 'baz'
|
---|
[6a3a178] | 96 | ```
|
---|
| 97 |
|
---|
| 98 | ## About
|
---|
| 99 |
|
---|
[e29cc2e] | 100 | <details>
|
---|
| 101 | <summary><strong>Contributing</strong></summary>
|
---|
[6a3a178] | 102 |
|
---|
[e29cc2e] | 103 | Pull requests and stars are always welcome. For bugs and feature requests, [please create an issue](../../issues/new).
|
---|
[6a3a178] | 104 |
|
---|
[e29cc2e] | 105 | </details>
|
---|
[6a3a178] | 106 |
|
---|
[e29cc2e] | 107 | <details>
|
---|
| 108 | <summary><strong>Running Tests</strong></summary>
|
---|
[6a3a178] | 109 |
|
---|
[e29cc2e] | 110 | Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command:
|
---|
[6a3a178] | 111 |
|
---|
[e29cc2e] | 112 | ```sh
|
---|
| 113 | $ npm install && npm test
|
---|
| 114 | ```
|
---|
| 115 |
|
---|
| 116 | </details>
|
---|
[6a3a178] | 117 |
|
---|
[e29cc2e] | 118 | <details>
|
---|
| 119 | <summary><strong>Building docs</strong></summary>
|
---|
[6a3a178] | 120 |
|
---|
| 121 | _(This project's readme.md is generated by [verb](https://github.com/verbose/verb-generate-readme), please don't edit the readme directly. Any changes to the readme must be made in the [.verb.md](.verb.md) readme template.)_
|
---|
| 122 |
|
---|
| 123 | To generate the readme, run the following command:
|
---|
| 124 |
|
---|
| 125 | ```sh
|
---|
| 126 | $ npm install -g verbose/verb#dev verb-generate-readme && verb
|
---|
| 127 | ```
|
---|
| 128 |
|
---|
[e29cc2e] | 129 | </details>
|
---|
[6a3a178] | 130 |
|
---|
[e29cc2e] | 131 | ### Related projects
|
---|
[6a3a178] | 132 |
|
---|
[e29cc2e] | 133 | You might also be interested in these projects:
|
---|
| 134 |
|
---|
| 135 | * [is-accessor-descriptor](https://www.npmjs.com/package/is-accessor-descriptor): Returns true if a value has the characteristics of a valid JavaScript accessor descriptor. | [homepage](https://github.com/jonschlinkert/is-accessor-descriptor "Returns true if a value has the characteristics of a valid JavaScript accessor descriptor.")
|
---|
| 136 | * [is-data-descriptor](https://www.npmjs.com/package/is-data-descriptor): Returns true if a value has the characteristics of a valid JavaScript data descriptor. | [homepage](https://github.com/jonschlinkert/is-data-descriptor "Returns true if a value has the characteristics of a valid JavaScript data descriptor.")
|
---|
| 137 | * [is-descriptor](https://www.npmjs.com/package/is-descriptor): Returns true if a value has the characteristics of a valid JavaScript descriptor. Works for… [more](https://github.com/jonschlinkert/is-descriptor) | [homepage](https://github.com/jonschlinkert/is-descriptor "Returns true if a value has the characteristics of a valid JavaScript descriptor. Works for data descriptors and accessor descriptors.")
|
---|
| 138 | * [isobject](https://www.npmjs.com/package/isobject): Returns true if the value is an object and not an array or null. | [homepage](https://github.com/jonschlinkert/isobject "Returns true if the value is an object and not an array or null.")
|
---|
| 139 |
|
---|
| 140 | ### Contributors
|
---|
| 141 |
|
---|
| 142 | | **Commits** | **Contributor** |
|
---|
| 143 | | --- | --- |
|
---|
| 144 | | 21 | [jonschlinkert](https://github.com/jonschlinkert) |
|
---|
| 145 | | 2 | [realityking](https://github.com/realityking) |
|
---|
[6a3a178] | 146 |
|
---|
| 147 | ### Author
|
---|
| 148 |
|
---|
| 149 | **Jon Schlinkert**
|
---|
| 150 |
|
---|
| 151 | * [github/jonschlinkert](https://github.com/jonschlinkert)
|
---|
| 152 | * [twitter/jonschlinkert](https://twitter.com/jonschlinkert)
|
---|
| 153 |
|
---|
| 154 | ### License
|
---|
| 155 |
|
---|
| 156 | Copyright © 2017, [Jon Schlinkert](https://github.com/jonschlinkert).
|
---|
| 157 | Released under the [MIT License](LICENSE).
|
---|
| 158 |
|
---|
| 159 | ***
|
---|
| 160 |
|
---|
[e29cc2e] | 161 | _This file was generated by [verb-generate-readme](https://github.com/verbose/verb-generate-readme), v0.6.0, on November 01, 2017._ |
---|