Détail du package

each-props

gulpjs6.4mMIT3.0.0

Processes each properties of an object deeply.

deep, each, object, property

readme

each-props

NPM version Downloads Build Status Coveralls Status

Processes each properties of an object deeply.

Install

To install from npm:

$ npm i each-props --save

Usage

Apply a function to all (non plain object) properties.

const eachProps = require('each-props');

var obj = { a: 1, b: { c: 'CCC', d: { e: 'EEE' } } };

eachProps(obj, function (value, keyChain, nodeInfo) {
  if (keyChain === 'a') {
    nodeInfo.parent['a'] = value * 2;
  } else if (keyChain === 'b.c') {
    nodeInfo.parent['c'] = value.toLowerCase();
  } else if (keyChain === 'b.d') {
    return true; // stop to dig
  } else if (keyChain === 'b.d.e') {
    nodeInfo.parent['e'] = value.toLowerCase();
  }
});

console.log(obj);
// => { a: 2, b: { c: 'ccc', d: { e: 'EEE' } } };

API

eachProps(obj, fn [, opts]) : void

Executes the fn function for all properties.

Parameters:

Parameter Type Description
obj object A plain object to be treated.
fn function A function to operate each properties.
opts object An object to pass any data to each properties.
  • API of fn function

    fn(value, keyChain, nodeInfo) : boolean

    This function is applied to all properties in an object.

    Parameters:

    | Parameter | Type | Description | | :--------- | :----: | :------------------------------------------------------------------ | | value | any | A property value. | | keyChain | string | A string concatenating the hierarchical keys with dots. | | nodeInfo | object | An object which contains node informations (See below). |

    Returns:

    True, if stops digging child properties.

    Type: boolean

  • Properties of nodeInfo

    | Properties | Type | Description | | :--------- | :------: | :---------------------------------------------------------------------------------------------------------- | | name | string | The property name of this node. | | index | number | The index of the property among the sibling properties. | | count | number | The count of the sibling properties. | | depth | number | The depth of the property. | | parent | object | The parent node of the property. | | sort | function | A sort function which orders the child properties. This function is inherited from opts, if be specified. |

    ... and any properties inherited from opts.

  • Properties of opts

    | Properties | Type | Description | | :--------- | :------: | :----------------------------------------------------------------- | | sort | function | A sort function which orders the same level properties. (Optional) |

    ... and any properties you want to pass to each node.

License

MIT

changelog

Changelog

3.0.0 (2022-10-02)

⚠ BREAKING CHANGES

  • Remove pre-built browser bundle & browser tests (#9)

Bug Fixes

  • ci: Add eslint-plugin-node for node 16 (2bae7e6)
  • ci: Correct prettierignore typo (73e1392)

Miscellaneous Chores

  • Remove pre-built browser bundle & browser tests (#9) (3f75efd)

2.0.0 (2021-09-27)

⚠ BREAKING CHANGES

  • Normalize repository, dropping node <10.13 support (#5)

Miscellaneous Chores

  • Normalize repository, dropping node <10.13 support (#5) (779fed2)