查询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 文件大小判断的实现代码
Apr 07 Javascript
获取dom元素那些讨厌的位置封装代码
Jun 23 Javascript
基于jquery的禁用右键、文本选择功能、复制按键的实现代码
Aug 27 Javascript
jquery中获取id值方法小结
Sep 22 Javascript
jQuery拖拽 &amp; 弹出层 介绍与示例
Dec 27 Javascript
分享33个jQuery与CSS3实现的绚丽鼠标悬停效果
Dec 15 Javascript
Jquery判断form表单数据是否变化
Mar 30 Javascript
location.hash保存页面状态的技巧
Apr 28 Javascript
BootStrap中的table实现数据填充与分页应用小结
May 26 Javascript
详解AngularJs中$sce与$sceDelegate上下文转义服务
Sep 21 Javascript
js数组去重的N种方法(小结)
Jun 07 Javascript
uniapp引入支付宝原生扫码插件步骤详解
Jul 23 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
第四节--构造函数和析构函数
2006/11/16 PHP
PHP中对用户身份认证实现两种方法
2011/06/04 PHP
使用php将某个目录下面的所有文件罗列出来的方法详解
2013/06/21 PHP
yii的CURD操作实例详解
2014/12/04 PHP
PHP读取word文档的方法分析【基于COM组件】
2017/08/01 PHP
php 可变函数使用小结
2018/06/12 PHP
JQuery 学习笔记 element属性控制
2009/07/23 Javascript
JQuery中使用Ajax赋值给全局变量失败异常的解决方法
2014/08/18 Javascript
jQuery可见性过滤器:hidden和:visibility用法实例
2015/06/24 Javascript
js实现遍历含有input的table实例
2015/12/07 Javascript
Bootstrap模仿起筷首页效果
2016/05/09 Javascript
javascript使用闭包模拟对象的私有属性和方法
2016/10/05 Javascript
浅谈Node Inspector 代理实现
2017/10/19 Javascript
JS中使用new Option()实现时间联动效果
2018/12/10 Javascript
vue+elementUI动态增加表单项并添加验证的代码详解
2020/12/17 Vue.js
[52:22]EG vs VG Supermajor小组赛B组 BO3 第一场 6.2
2018/06/03 DOTA
在Python中操作字符串之replace()方法的使用
2015/05/19 Python
python类中super()和__init__()的区别
2016/10/18 Python
python中MethodType方法介绍与使用示例
2017/08/03 Python
Python获取CPU、内存使用率以及网络使用状态代码
2018/02/08 Python
Python2.7.10以上pip更新及其他包的安装教程
2018/06/12 Python
Python简单I/O操作示例
2019/03/18 Python
Python实现计算文件MD5和SHA1的方法示例
2019/06/11 Python
Python获取命令实时输出-原样彩色输出并返回输出结果的示例
2019/07/11 Python
Django-Model数据库操作(增删改查、连表结构)详解
2019/07/17 Python
使用sklearn的cross_val_score进行交叉验证实例
2020/02/28 Python
可视化pytorch 模型中不同BN层的running mean曲线实例
2020/06/24 Python
英国家庭和商业健身器材购物网站:Fitness Options
2018/07/05 全球购物
投标承诺书范本
2014/03/27 职场文书
学校春季防火方案
2014/06/08 职场文书
网络工程专业大学生求职信
2014/10/01 职场文书
奖学金发言稿(范文)
2019/08/21 职场文书
python数据库批量插入数据的实现(executemany的使用)
2021/04/30 Python
HTML5页面音频自动播放的实现方式
2021/06/21 HTML / CSS
MySQL中存储时间的最佳实践指南
2021/07/01 MySQL
教你部署vue项目到docker
2022/04/05 Vue.js