HaXeho e0dad002ed first commit 10 kuukautta sitten
..
.github e0dad002ed first commit 10 kuukautta sitten
test e0dad002ed first commit 10 kuukautta sitten
.eslintrc e0dad002ed first commit 10 kuukautta sitten
.nycrc e0dad002ed first commit 10 kuukautta sitten
CHANGELOG.md e0dad002ed first commit 10 kuukautta sitten
LICENSE e0dad002ed first commit 10 kuukautta sitten
README.md e0dad002ed first commit 10 kuukautta sitten
index.d.ts e0dad002ed first commit 10 kuukautta sitten
index.d.ts.map e0dad002ed first commit 10 kuukautta sitten
index.js e0dad002ed first commit 10 kuukautta sitten
package.json e0dad002ed first commit 10 kuukautta sitten
tsconfig.json e0dad002ed first commit 10 kuukautta sitten

README.md

define-data-property Version Badge

github actions coverage License Downloads

npm badge

Define a data property on an object. Will fall back to assignment in an engine without descriptors.

The three non* argument can also be passed null, which will use the existing state if available.

The loose argument will mean that if you attempt to set a non-normal data property, in an environment without descriptor support, it will fall back to normal assignment.

Usage

var defineDataProperty = require('define-data-property');
var assert = require('assert');

var obj = {};
defineDataProperty(obj, 'key', 'value');
defineDataProperty(
	obj,
	'key2',
	'value',
	true, // nonEnumerable, optional
	false, // nonWritable, optional
	true, // nonConfigurable, optional
	false // loose, optional
);

assert.deepEqual(
	Object.getOwnPropertyDescriptors(obj),
	{
		key: {
			configurable: true,
			enumerable: true,
			value: 'value',
			writable: true,
		},
		key2: {
			configurable: false,
			enumerable: false,
			value: 'value',
			writable: true,
		},
	}
);