Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@jalik/extend

Package Overview
Dependencies
Maintainers
1
Versions
22
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@jalik/extend

A utility to merge objects.

  • 1.0.3
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
27
decreased by-12.9%
Maintainers
1
Weekly downloads
 
Created
Source

jk-extend

A utility to merge objects.

Introduction

Useful when you need to merge two or more objects into one.

This library is tested with unit tests.

Merging objects

In this example, all objects are merged into the first object, so the first object is modified, if you don't want to modify the object, pass en empty object {} as the first argument.

Note that objects are merged based on their order, so the 2nd object is merged in the first, then the 3rd is merged in the first, and so on... Keep in mind that first objects may be overridden by following objects.

import {extend} from "@jalik/extend";

const coldColors = {
    blue: "#0000FF",
    green: "#00FF00"
};

const hotColors = {
    red: "#FF0000",
    yellow: "#FFF000"
};

const customColors = {
    cyan: "#5BF8FF",
    pink: "#FF4CFB"
};

// Merge all colors in a new object
const mixedColors = extend({}, hotColors, coldColors, customColors);

Merging objects recursively

In the previous example, all objects were flat, but it works also with deep objects and nested attributes.

import {extendRecursively} from "@jalik/extend";

const colorSet1 = {
    cold: {
        blue: "#0000FF",
        green: "#00FF00"
    },
    hot: {
        red: "#FF0000",
        yellow: "#FFF000"
    },
    custom: {
      cyan: "#5BF8FF",
      pink: "#FF4CFB"
    }
};

const colorSet2 = {
    cold: {
        blue: "#0011AA",
        green: "#00AA11"
    },
    hot: {
        red: "#AA0011",
        yellow: "#AAA111"
    }
};

// Merge all colors in a new object
const mixedColors = extendRecursively({}, colorSet1, colorSet2);

Changelog

History of releases is in the changelog.

License

The code is released under the MIT License.

Keywords

FAQs

Package last updated on 11 Oct 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc