查询json的数据结构的8种方式简介


Posted in Javascript onMarch 10, 2014

查询json的数据结构的8种方式:

JsonSQL

JsonSQL实现了使用SQL select语句在json数据结构中查询的功能。主页:http://www.trentrichardson.com/jsonsql/

例子:

jsonsql.query("select * from json.channel.items order by title desc",json);

JSONPath

JSONPath就像是针对JSON数据结构的XPath。主页:http://goessner.net/articles/JsonPath/

例子:

jsonPath( books, '$..book[(@.length-1)]')

jfunk

jFunk允许你检索(很快会加入管理功能)复杂的JSON或Javascript对象。jFunk API的设计几乎与jQuery API类似。它直接复制了jQuery的API,除了那些针对DOM的API。
主页:http://code.google.com/p/jfunk/

例子:

Jf("> vegetables > *[color=Orange]",Food).get();

TaffyDB

你过去有没有注意到Javascript对象的字面值看起来很像记录?如果你把他们包裹在一个数组里面,那么它们看起来有没有像一个数据库表?TaffyDB是一个Javascript库,它提供了强大的数据库功能以实现之前的想法,大大改善了你在Javascript中使用数据的方式。
主页:http://www.taffydb.com/

例子:

var kelly = friends({id:2}).first();

linq.js

linq.js——Javascript中的LINQ

var queryResult2 = Enumerable.From(jsonArray)
    .Where("$.user.id < 200")
    .OrderBy("$.user.screen_name")
    .Select("$.user.screen_name + ':' + $.text")
    .ToArray();

objeq

objeq是一个简单的库,实现了对POJSO(Plain-Old JavaScript Objects,普通的Javascript对象)的实时查询。主页:https://github.com/agilosoftware/objeq

var res = $objeq(data, "age > 40 && gender == 'female' -> name");
// --> Returns ['Jessica']

(译注:它使用了Javascript的property setters,所以它只能工作在较新的浏览器上)

json:select()

使用类CSS选择符来查询JSON。主页:http://jsonselect.org/#tryit

.lang:val("Bulgarian") ~ .level

Paul的编程珠玑中的Javascript数组过滤方法,主页:http://www.paulfree.com/28/javascript-array-filtering/#more-28

var a = [1,2,3,4,5,6,7,8,9,10];
 // return everything
a.where( "( ) => true" ) ;
//  --> [1,2,3,4,5,6,7,8,9,10]
// return even numbers
a.where( "( n, i ) => n % 2 == 0" ) ;
//  --> [2,4,6,8,10]
// query first 6 products whose category begins with 'con' using extra param and regular expression
products.where( "( el, i, res, param ) => res.length <= 6 && param.test( el.cat )", /^con/i);
// using customer table data from SQL Server's northwind database...    
customers.where( "( el, i, res, param ) => el.country == param", "USA" );

目前这是我最喜欢的查询JSON数据结构的方法。它非常的简单,并且据作者所说它非常快。
它背后的理念和John Resig的JavaScript Micro-Templating类似:使用正确表达式将一段非常简单的字符串转换成Javascript函数。
当然,还有更多强大的解决方案。Paul实现的原型还缺少对过滤表达式的语法检查,但是我相信你应该可以自己解决Javscript的语法检查。

Javascript 相关文章推荐
js动态加载以及确定加载完成的代码
Jul 31 Javascript
JavaScript 更严格的相等 [译]
Sep 20 Javascript
JS判定是否原生方法
Jul 22 Javascript
Javascript页面添加到收藏夹的简单方法
Aug 07 Javascript
jQuery中[attribute^=value]选择器用法实例
Dec 31 Javascript
原生js与jQuery实现简单的tab切换特效对比
Jul 30 Javascript
JSON+Jquery省市区三级联动
Jan 13 Javascript
jQuery基于json与cookie实现购物车的方法
Apr 15 Javascript
JavaScript调试之console.log调试的一个小技巧分享
Aug 07 Javascript
Angular2整合其他插件的方法
Jan 20 Javascript
Vue实现导出excel表格功能
Mar 30 Javascript
vue实现路由懒加载的3种方法示例
Sep 01 Javascript
js 3秒后跳转页面的实现代码
Mar 10 #Javascript
php is_numberic函数造成的SQL注入漏洞
Mar 10 #Javascript
关于JavaScript对象的动态选择及遍历对象
Mar 10 #Javascript
使用js操作css实现js改变背景图片示例
Mar 10 #Javascript
红米手机抢购的js代码
Mar 10 #Javascript
按下回车键指向下一个位置的一个函数代码
Mar 10 #Javascript
用js判断输入是否为中文的函数
Mar 10 #Javascript
You might like
用PHP进行MySQL删除记录操作代码
2008/06/07 PHP
php下intval()和(int)转换使用与区别
2008/07/18 PHP
php使用PDO获取结果集的方法
2017/02/16 PHP
php基于自定义函数记录log日志方法
2017/07/21 PHP
javascript新手语法小结
2008/06/15 Javascript
JavaScript高级程序设计(第3版)学习笔记5 js语句
2012/10/11 Javascript
js Object2String方便查看js对象内容
2014/11/24 Javascript
nodejs 整合kindEditor实现图片上传
2015/02/03 NodeJs
理解js回收机制通俗易懂版
2016/02/29 Javascript
基于HTML+CSS+JS实现增加删除修改tab导航特效代码
2016/08/05 Javascript
JS限制条件补全问题实例分析
2016/12/16 Javascript
你真的了解BOM中的history对象吗
2017/02/13 Javascript
Vue使用vue-cli创建项目
2017/09/01 Javascript
JavaScript 中定义函数用 var foo = function () {} 和 function foo()区别介绍
2018/03/01 Javascript
详解Vue项目编译后部署在非网站根目录的解决方案
2018/04/26 Javascript
JavaScript实现百度搜索框效果
2020/03/26 Javascript
layui table去掉右侧滑动条的实现方法
2019/09/05 Javascript
element-ui 文件上传修改文件名的方法示例
2019/11/05 Javascript
Python序列之list和tuple常用方法以及注意事项
2015/01/09 Python
利用Python3分析sitemap.xml并抓取导出全站链接详解
2017/07/04 Python
Python实现一个简单的验证码程序
2017/11/03 Python
使用turtle绘制五角星、分形树
2019/10/06 Python
python3检查字典传入函数键是否齐全的实例
2020/06/05 Python
使用python实现名片管理系统
2020/06/18 Python
Python错误的处理方法
2020/06/23 Python
Pycharm-community-2020.2.3 社区版安装教程图文详解
2020/12/08 Python
PyTorch中的拷贝与就地操作详解
2020/12/09 Python
如何让IE9以下版本(ie6/7/8)认识html5元素
2013/04/01 HTML / CSS
建筑自我鉴定
2013/10/19 职场文书
大四毕业生学习总结的自我评价
2013/10/31 职场文书
大学生感恩父母演讲稿
2014/08/28 职场文书
幼儿园端午节活动总结
2015/05/05 职场文书
2015年政协委员工作总结
2015/05/20 职场文书
2015年政府采购工作总结
2015/05/21 职场文书
2016年秋季运动会加油稿
2015/12/21 职场文书
Python内置类型集合set和frozenset的使用详解
2022/04/26 Python