• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

javascript 程旭媛 7年前 (2018-06-21) 162次浏览 已收录 0个评论

  你有没有对“在复杂的jsON数据结构中查找匹配内容”而烦恼。这里有8种不同的方式可以做到:

  JsonSQL

  JsonSQL实现了使用SQL select语句在json数据结构中查询的功能。

  例子:

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

  主页:http://www.trentrichardson.com/jsonsql/

  JSONPath

  JSONPath就像是针对JSON数据结构的XPath。

  例子:

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

  主页:http://goessner.net/articles/JsonPath/

  jfunk

  jFunk允许你检索(很快会加入管理功能)复杂的JSON或JavaScript对象。jFunk API的设计几乎与jquery API类似。它直接复制了jQuery的API,除了那些针对DOM的API。

  例子:

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

  主页:http://code.google.com/p/jfunk/

  TaffyDB

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

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

  主页:http://www.taffydb.com/

  linq.js

  linq.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();

  主页:http://linqjs.codeplex.com/

  主页:http://neue.cc/reference.htm

  objeq

  objeq是一个简单的库,实现了对POJSO(Plain-Old JavaScript Objects,普通的Javascript对象)的实时查询。

 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

  主页:http://jsonselect.org/#tryit

  Paul的编程珠玑中的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" );

  主页:http://www.paulfree.com/28/javascript-array-filtering/#more-28

  目前这是我最喜欢的查询JSON数据结构的方法。它非常的简单,并且据作者所说它非常快。

  它背后的理念和John Resig的JavaScript Micro-Templating类似:使用正确表达式将一段非常简单的字符串转换成Javascript函数。

  当然,还有更多强大的解决方案。Paul实现的原型还缺少对过滤表达式的语法检查,但是我相信你应该可以自己解决Javscript的语法检查。

  最后,你必须决定哪个对于你的项目来说最好。

  英文原文:orangevolt,编译:搞代码gaodaima.com——周敏明

  译文链接:http://blog.jobbole.com/31166/

欢迎大家阅读《查询json数据结构的8种方式_js》,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:查询json数据结构的8种方式_js

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址