npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

cocotte-clone

v0.3.1

Published

deep copy

Downloads

7

Readme

cocotte-clone

値をディープコピーします
次のルールで複製されます

  • undefined,null,プリミティブの真偽値・数字・文字列は値そのものを返す
  • newで作成された真偽値・数字・文字列は同じコンストラクタのオブジェクトで返す
  • 日付と正規表現は同じ値を持つ引数に持つコンストラクタのオブジェクトで返す
  • エラーはmessageプロパティを引数に持つコンストラクタのオブジェクトで返す
  • 配列は各値毎にルールを適用した新しい配列を返す
  • オブジェクトはプロパティ毎ににルールを適用したもので返す
  • 列挙されないプロパティもその属性を保持したまま複製する
  • プロトタイプは複製元と同じ参照先が設定される
  • 関数は複製元と同じ参照が設定される
  • 循環参照が存在する場合は同じパスの参照先のオブジェクトへの参照が設定される

使用方法

var clone = require('cocotte-clone');
var original = {
  a: 1,
  b: 'foo',
  c: new Date(),
  d: [1, 2, {x: 1}]
};
var cloned = clone(original);

複数の値を渡した場合

全ての引数がオブジェクトの場合

オブジェクトをマージします
マージされた配列やオブジェクトの要素も全てディープコピーされています
第2引数以降のオブジェクトは、列挙可能なプロパティのみがマージの対象になります
マージ元のプロパティが列挙可能である必要はありません
マージ元のプロパティが書込み不可の場合はマージされません

var obj1 = {
  a: 1,
  b: {
    c: 2,
    d: 3
  }
};
var obj2 = {
  a: 4,
  b: {
    c: 5
  }
};
var obj3 = {
  a: 4,
  b: {
    c: 5,
    d: 3
  }
};
assert.deepEqual(clone(obj1, obj2), obj3); // pass

その他

ディープコピー後に配列として返します
連結の際はArray.concatと同じ動作をします

var cloned = clone(1, [2, 3], [4, 5]); // [1, 2, 3, 4, 5]