查询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 相关文章推荐
jQuery 源码分析笔记(5) jQuery.support
Jun 19 Javascript
用Javascript评估用户输入密码的强度实现代码
Nov 30 Javascript
Node.js文件操作详解
Aug 16 Javascript
jquery+ajax验证不通过也提交表单问题处理
Dec 12 Javascript
分享经典的JavaScript开发技巧
Nov 21 Javascript
JavaScript动态添加css样式和script标签
Jul 19 Javascript
vue中设置height:100%无效的问题及解决方法
Jul 27 Javascript
jquery 验证用户名是否重复代码实例
May 14 jQuery
Webpack按需加载打包chunk命名的方法
Sep 22 Javascript
jQuery三组基本动画与自定义动画操作实例总结
May 09 jQuery
在vue中使用eslint,配合vscode的操作
Nov 09 Javascript
解决vue-cli输入命令vue ui没效果的问题
Nov 17 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
10条PHP高级技巧[修正版]
2011/08/02 PHP
PHP的魔术常量__METHOD__简介
2014/07/08 PHP
PHP图片处理之图片旋转和图片翻转实例
2014/11/19 PHP
MooTools 页面滚动浮动层智能定位实现代码
2011/08/23 Javascript
Jquery的hover方法让鼠标经过li时背景变色
2013/09/06 Javascript
如何动态的导入js文件具体该怎么实现
2014/01/14 Javascript
一段非常简单的js判断浏览器的内核
2014/08/17 Javascript
jquery解析json格式数据的方法(对象、字符串)
2015/11/24 Javascript
jQuery筛选数组之grep、each、inArray、map的用法及遍历json对象
2016/06/20 Javascript
Bootstrap简单表单显示学习笔记
2016/11/15 Javascript
自定义require函数让浏览器按需加载Js文件
2016/11/24 Javascript
微信小程序实现图片懒加载的示例代码
2017/12/13 Javascript
react中使用swiper的具体方法
2018/05/15 Javascript
this在vue和小程序中的使用详解
2019/01/28 Javascript
如何利用ES6进行Promise封装总结
2019/02/11 Javascript
小程序实现悬浮搜索框
2019/07/12 Javascript
JS实现移动端双指缩放和旋转方法
2019/12/13 Javascript
JavaScript正则表达式验证登录实例
2020/03/18 Javascript
ES5新增数组的实现方法
2020/05/12 Javascript
python转换摩斯密码示例
2014/02/16 Python
Python的collections模块中namedtuple结构使用示例
2016/07/07 Python
关于python的list相关知识(推荐)
2017/08/30 Python
Python+OpenCV实现车牌字符分割和识别
2018/03/31 Python
Python实现获取汉字偏旁部首的方法示例【测试可用】
2018/12/18 Python
Python Selenium参数配置方法解析
2020/01/19 Python
利用python控制Autocad:pyautocad方式
2020/06/01 Python
python实现猜数游戏(保存游戏记录)
2020/06/22 Python
Python离线安装各种库及pip的方法
2020/11/28 Python
python 实现ping测试延迟的两种方法
2020/12/10 Python
Python从MySQL数据库中面抽取试题,生成试卷
2021/01/14 Python
SmartBuyGlasses意大利:购买太阳镜、眼镜和隐形眼镜
2018/11/20 全球购物
阿联酋优惠券服务:Living Kool
2019/12/12 全球购物
毕业生应聘幼儿园的自荐信
2013/11/20 职场文书
四风问题对照检查材料思想汇报
2014/10/07 职场文书
2014年保管员工作总结
2014/11/18 职场文书
Ubuntu安装Mysql+启用远程连接的完整过程
2022/06/21 Servers