查询 json 数据结构的 8 种方式_前端开发者

前端开发者web前端
https://www.rokub.com
查询 JSON 数据结构的 8 种方式你有没有对“在复杂的JSON数据结构中查找匹配内容”而烦恼。
这里有8种不同的方式可以做到:JsonSQLJsonSQL实现了使用SQL select语句在json数据结构中查询的功能。
例子:jsonsql.query(“select * from json.channel.items order by title desc”,json); 1 jsonsql . query ( “select * from json.channel.items order by title desc” , json ) ;主页:http://www.trentrichardson.com/jsonsql/JSONPathJSONPath就像是针对JSON数据结构的XPath。
例子:jsonPath( books, ‘$..book[(@.length-1)]’) 1 jsonPath ( books , ‘$..book[(@.length-1)]’ )主页:http://goessner.net/articles/JsonPath/jfunkjFunk允许你检索(很快会加入管理功能)复杂的JSON或Javascript对象。
jFunk API的设计几乎与jquery API类似。
它直接复制了jquery的API,除了那些针对DOM的API。
例子:Jf(“> vegetables > *[color=Orange]”,Food).get(); 1 Jf ( “> vegetables > *[color=Orange]” , Food ) . get ( ) ;主页:http://code.google.com/p/jfunk/TaffyDB你过去有没有注意到Javascript对象的字面值看起来很像记录?如果你把他们包裹在一个数组里面,那么它们看起来有没有像一个数据库表?TaffyDB是一个Javascript库,它提供了强大的数据库功能以实现之前的想法,大大改善了你在Javascript中使用数据的方式。
var kelly = friends({id:2}).first(); 1 var kelly = friends ( { id : 2 } ) . first ( ) ;主页:http://www.taffydb.com/linq.jslinq.js——Javascript中的LINQ(译者注:.Net中的概念,见http://msdn.microsoft.com/zh-tw/library/bb397897)var queryResult2 = Enumerable.From(jsonArray) .Where(“$.user.id < 200”) .OrderBy(“$.user.screen_name”) .Select(“$.user.screen_name + ‘:’ + $.text”) .ToArray(); 1 2 3 4 5 var queryResult2 = Enumerable . From ( jsonArray ) . Where ( “$.user.id < 200” ) . OrderBy ( “$.user.screen_name” ) . Select ( “$.user.screen_name + ‘:’ + $.text” ) . ToArray ( ) ;主页:http://linqjs.codeplex.com/主页:http://neue.cc/reference.htmobjeqobjeq是一个简单的库,实现了对POJSO(Plain-Old JavaScript Objects,普通的Javascript对象)的实时查询。
var res = $objeq(data, “age > 40 && gender == ‘female’ -> name”); // –> Returns [‘Jessica’] 1 2 var res = $ objeq ( data , “age > 40 && gender == ‘female’ -> name” ) ; // –> Returns [‘Jessica’]主页:https://github.com/agilosoftware/objeq(译注:它使用了Javascript的property setters,所以它只能工作在较新的浏览器上)json:select()使用类css选择符来查询JSON。
.lang:val(“Bulgarian”) ~ .level 1 . lang : val ( “Bulgarian” ) ~ . level主页:http://jsonselect.org/#tryitPaul的编程珠玑中的Javascript数组过滤方法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” ); 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 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” ) ;主页:http://www.paulfree.com/28/javascript-array-filtering/#more-28目前这是我最喜欢的查询JSON数据结构的方法。
它非常的简单,并且据作者所说它非常快。
它背后的理念和John Resig的JavaScript Micro-Templating类似:使用正确表达式将一段非常简单的字符串转换成Javascript函数。
当然,还有更多强大的解决方案。
Paul实现的原型还缺少对过滤表达式的语法检查,但是我相信你应该可以自己解决Javscript的语法检查。
最后,你必须决定哪个对于你的项目来说最好。
英文原文:orangevolt,编译:伯乐在线——周敏明译文链接:http://blog.jobbole.com/31166/【如需转载,请在正文中标注并保留原文链接、译文链接和译者等信息,谢谢合作!
» 本文来自:前端开发者 » 《查询 json 数据结构的 8 种方式_前端开发者》
» 本文链接地址:https://www.rokub.com/2166.html
» 您也可以订阅本站:https://www.rokub.com
赞(0)
64K

评论 抢沙发

评论前必须登录!