Skip to content

matsuby/easydot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

47 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

easydot

MIT License

easydot provides "dot-string access" for target object.

e.g) console.log(easydot({a:{b:{c:42}}})["a.b.c"]); // => 42

Installing

For Browser (CDN)

<script src="https://cdn.jsdelivr.net/gh/matsuby/easydot/dist/easydot.min.js"></script>

For Node.js

// Install from npm
npm install --save easydot

// Install from yarn
yarn add easydot

and

// Use ES Modules
import easydot from "easydot";

// Use Common JS
const easydot = require("easydot");

Usage

const target = {
  what: {
    is: {
      easydot: 42
    }
  }
};

// create proxy that implements `dot-string acccess`
const proxy = easydot(target);

// get nested property
console.log(proxy["what.is.easydot"]);
// => 42

// set nested property
proxy["what.is.easydot"] = "set value";
console.log(proxy.what.is.easydot);
// => "set value"

// this is a just proxy, so target status was affected
proxy["what.is.name"] = "john";
console.log(JSON.stringify(target, null, 2));
// =>
// {
//  "what": {
//    "is": {
//      "easydot": "set value",
//      "name": "john"
//    }
//  }
// }

Over jump access

const target = {
  what: {
    is: {
      easydot: 42
    }
  }
};

// unsafe over jump access(default)
const unsafeProxy = easydot(target);
try {
  unsafeProxy["not.exist.property"];
} catch (e) {
  console.error("error");
}


// safe over jump access(optional)
const safeProxy = easydot(target, true);
safeProxy["not.exist.property"] = "safe";

About

"dot-string access" for target object

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •