chen.cheng 7498f5b8cc init 11 tháng trước cách đây
..
.github 7498f5b8cc init 11 tháng trước cách đây
test 7498f5b8cc init 11 tháng trước cách đây
.eslintrc 7498f5b8cc init 11 tháng trước cách đây
.nycrc 7498f5b8cc init 11 tháng trước cách đây
CHANGELOG.md 7498f5b8cc init 11 tháng trước cách đây
LICENSE 7498f5b8cc init 11 tháng trước cách đây
README.md 7498f5b8cc init 11 tháng trước cách đây
index.d.ts 7498f5b8cc init 11 tháng trước cách đây
index.js 7498f5b8cc init 11 tháng trước cách đây
package.json 7498f5b8cc init 11 tháng trước cách đây
tsconfig.json 7498f5b8cc init 11 tháng trước cách đây

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,
		},
	}
);