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 🙏

© 2025 – Pkg Stats / Ryan Hefner

json-clip

v0.0.2

Published

json data clip

Downloads

3

Readme

简介

json-clip 实现了类似grahlql基于查询裁剪对象的功能

特性

1.声明式写法 2.结构化查询语句 3.支持路径查找对象 4.支持数组对象裁剪 5.支持数组第n项裁剪 6.辅助工具: d2-pojo裁剪

##使用方式

  var d2 = require('json-clip');
  const data = d2(query, source);
  //data为查询后的数据
  
  查询支持:路径查询 如:'a.b.c',其中'.'表示当前路径,那就是当前key
  路径查询,操作函数: d2.dot(path,defaultValue,queryobj);

使用例子

//源数据
{
  smaple: "1",
  list: [
    {
      first: 1,
      seconde: 2,
      three: {
        h: 1,
        g: "ff"
      }
    },
    {
      first: 1,
      seconde: 2,
      three: {
        h: 2,
        g: "ffg"
      }
    }
  ],
  data: {
    smaple: "1",
    smapleObje: {
      x: "xxx",
      a: {
        wo: "123"
      },
      b: {
        wo: "123"
      }
    },
    list: [{ first: "list1", seconde: 2 }, { first: 1, seconde: 2 }],
    obx: {
      limit: 1,
      offset: 2,
      items: [
        {
          monther: "nilaomao",
          father: "nidaye"
        },
        {
          monther: "nilaomao",
          father: "nidaye"
        }
      ]
    }
  },
  array: {
    limit: 1,
    offset: 2,
    items: [
      {
        monther: "nilaomao",
        father: "nidaye"
      },
      {
        monther: "nilaomao2",
        father: "nidaye2"
      }
    ]
  }
}

查询

1.单间数据抽取
const query1 = {
  smaple: "."
};

结果: { "smaple": "1" }

2.生成数据抽取,保持原有数据层次
const query2 = {
  data: {
    smapleObje: "."
  }
};

结果: { "data": { "smapleObje": { "x": "xxx", "a": { "wo": "123" }, "b": { "wo": "123" } } } }

3.数组内抽取
const query3 = {
  array: {
    items: {
      monther: "."
    }
  }
};

结果: { "array": { "items": [ { "monther": "nilaomao" }, { "monther": "nilaomao2" } ] } }

4.数组第n项目抽取
const query4 = {
  array: ".items.0"
};

结果: { "array": { "monther": "nilaomao", "father": "nidaye" } }

5.数组第n项目抽取后再裁剪
const query5 = {
  array: d2.dot(".items.1", null, {
    monther: "."
  })
};

结果: { "array": { "monther": "nilaomao2" } }

6.数组第n项目抽取后再裁剪&转换
const query5_1 = {
  array: d2.dot(".items.1", null, {
    monther: value => "妈妈" + value
  })
};

结果: { "array": { "monther": "妈妈nilaomao2" } }

7.额外元素新增(新增的元素不能原有同层元素同名),新增元素查询path不能 . 开头
const query6 = {
  bobocustom: "data.smapleObje"
};

结果:{ "bobocustom": { "x": "xxx", "a": { "wo": "123" }, "b": { "wo": "123" } } }

8.额外元素新增,并裁剪
const query7 = {
  bobocustom: d2.dot("data.smapleObje", null, { a: "." })
};

结果:{ "bobocustom": { "a": { "wo": "123" } } }

9.额外元素新增
const query8 = {
  xxx: d2.dot(".", [{ four: 10 }, { four: 11 }, { four: 12 }])
};

结果:{ "xxx": [ { "four": 10 }, { "four": 11 }, { "four": 12 } ] }

10.额外元素抽取生成数组数据并裁剪数组元素
const query9 = {
  bobocustom: d2.dot("data.list", null, {
    first: d2.any() /*d2.any()等同于 ‘.’ */
  })
};

结果:{ "bobocustom": [ { "first": "list1" }, { "first": 1 } ] }

11.数据转换
const query10 = {
  smaple: value => value + "mmm"
};

结果: "smaple": "1mmm" }

12.数组元数据 裁剪&转换,value代表 key 在原source中的值
const query11 = {
  bobocustom: d2.dot("data.list", null, {
    first: value => undefined, //和直接不写first 这节点一样
    seconde: "."
  })
};

结果:{ "bobocustom": [ { "seconde": 2 }, { "seconde": 2 } ] }