4.7.84 • Published 2 years ago

@taktikorg/quos-tenetur-cum v4.7.84

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

@taktikorg/quos-tenetur-cum Version Badge

github actions coverage License Downloads

npm badge

Define an accessor property on an object. In an engine without descriptors, in loose mode, when only a getter is provided, nonEnumerable is false, and nonConfigurable is false, wil fall back to assignment - otherwise, it will throw.

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

The loose option will mean that if you attempt to set a nonconfigurable/nonwritable accessor property with set, in an environment without descriptor support, it will fall back to normal assignment (and eagerly evaluate the getter).

Usage

var defineAccessorProperty = require('@taktikorg/quos-tenetur-cum');
var assert = require('assert');

var str = 'value';
var strThunk = function () { return str; };
var strSetter = function (v) { str = v; };
var random = function () { return Math.random(); };

var obj = {};
defineAccessorProperty(
	obj,
	'key',
	{
		get: strThunk,
		set: strSetter,
	}
);
defineAccessorProperty(
	obj,
	'key2',
	{
		get: random, // at least one of "get" or "set" must be provided
		nonConfigurable: true, // optional
		nonEnumerable: true, // optional
		loose: false, // optional
	}
);

assert.deepEqual(
	Object.getOwnPropertyDescriptors(obj),
	{
		key: {
			configurable: true,
			enumerable: true,
			get: strThunk,
			set: strSetter,
		},
		key2: {
			configurable: false,
			enumerable: false,
			get: random,
			set: undefined,
		},
	}
);
4.7.84

2 years ago

4.7.83

2 years ago

4.7.82

2 years ago

4.7.81

2 years ago

4.7.80

2 years ago

4.7.79

2 years ago

4.7.78

2 years ago

4.7.77

2 years ago

4.7.76

2 years ago

4.7.75

2 years ago

4.7.74

2 years ago

4.7.73

2 years ago

4.6.73

2 years ago

4.6.72

2 years ago

4.6.71

2 years ago

4.6.70

2 years ago

4.6.69

2 years ago

4.6.68

2 years ago

4.6.67

2 years ago

4.6.66

2 years ago

4.6.65

2 years ago

4.5.65

2 years ago

4.5.64

2 years ago

4.5.63

2 years ago

4.5.62

2 years ago

4.5.61

2 years ago

4.5.60

2 years ago

4.5.59

2 years ago

4.5.58

2 years ago

4.5.57

2 years ago

4.5.56

2 years ago

4.5.55

2 years ago

4.5.54

2 years ago

4.5.53

2 years ago

4.5.52

2 years ago

4.5.51

2 years ago

4.5.50

2 years ago

4.4.50

2 years ago

3.4.50

2 years ago

3.4.49

2 years ago

3.4.48

2 years ago

3.4.47

2 years ago

3.4.46

2 years ago

3.4.45

2 years ago

3.4.44

2 years ago

3.4.43

2 years ago

3.4.42

2 years ago

3.4.41

2 years ago

3.4.40

2 years ago

3.4.39

2 years ago

3.4.38

2 years ago

3.4.37

2 years ago

3.4.36

2 years ago

3.4.35

2 years ago

3.4.34

2 years ago

3.4.33

2 years ago

3.4.32

2 years ago

3.4.31

2 years ago

3.4.30

2 years ago

3.4.29

2 years ago

3.4.28

2 years ago

3.4.27

2 years ago

3.4.26

2 years ago

3.4.25

2 years ago

3.3.25

2 years ago

3.3.24

2 years ago

3.3.23

2 years ago

3.3.22

2 years ago

3.3.21

2 years ago

3.2.21

2 years ago

3.2.20

2 years ago

3.2.19

2 years ago

3.2.18

2 years ago

3.2.17

2 years ago

3.2.16

2 years ago

3.2.15

2 years ago

2.2.15

2 years ago

2.2.14

2 years ago

2.1.14

2 years ago

2.1.13

2 years ago

2.0.13

2 years ago

2.0.12

2 years ago

2.0.11

2 years ago

2.0.10

2 years ago

2.0.9

2 years ago

2.0.8

2 years ago

1.0.8

2 years ago

1.0.7

2 years ago

1.0.6

2 years ago

1.0.5

2 years ago

1.0.4

2 years ago

1.0.3

2 years ago

1.0.2

2 years ago

1.0.1

2 years ago

1.0.0

2 years ago