你有没有对“在复杂的JSON数据结构中查找匹配内容”而烦恼。这里有8种不同的方式可以做到:
JsonSQL
JsonSQL实现了使用SQL select语句在json数据结构中查询的功能。
jsonsql.query("select * from json.channel.items order by title desc",json);
JSONPath
JSONPath就像是针对JSON数据结构的XPath。
例子:
jsonPath( books, '$..book[(@.length-1)]')
jfunk
jFunk允许你检索(很快会加入管理功能)复杂的JSON或Javascript对象。jFunk API的设计几乎与jQuery API类似。它直接复制了jQuery的API,除了那些针对DOM的API。
例子:
Jf(">vegetables>*[color=Orange]",Food).get();
TaffyDB
你过去有没有注意到Javascript对象的字面值看起来很像记录?如果你把他们包裹在一个数组里面,那么它们看起来有没有像一个数据库 表?TaffyDB是一个Javascript库,它提供了强大的数据库功能以实现之前的想法,大大改善了你在Javascript中使用数据的方式。
varkelly=friends({id:2}).first();
linq.js
varqueryResult2=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对象)的实时查询。
varres= $objeq(data, "age>40 &&gender== 'female' ->name");
// -->Returns ['Jessica']
(译注:它使用了Javascript的property setters,所以它只能工作在较新的 浏览器上)
json:select()
使用类CSS选择符来查询JSON。
.lang:val("Bulgarian") ~ .level
Paul的编程珠玑中的Javascript数组过滤方法
vara= [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的语法检查。
***,你必须决定哪个对于你的项目来说***。
【编辑推荐】
【责任编辑:chensf TEL:(010)68476606】
点赞 0