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

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

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

JsonSQL

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

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

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

JSONPath

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

例子:

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

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

jfunk

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

例子:

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

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

TaffyDB

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

  1. 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

  1. var queryResult2 = Enumerable.From(jsonArray) 
  2.     .Where("$.user.id < 200") 
  3.     .OrderBy("$.user.screen_name") 
  4.     .Select("$.user.screen_name + ':' + $.text") 
  5.     .ToArray(); 

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

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

objeq

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

  1. var res = $objeq(data, "age > 40 && gender == 'female' -> name"); 
  2.     // --> Returns ['Jessica'] 

主页: https://github.com/agilosoftware/objeq

(译注:它使用了Javascript的property setters,所以它只能工作在较新的 浏览器上)

json:select()

使用类CSS选择符来查询JSON。

  1. .lang:val("Bulgarian") ~ .level 

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

Paul的编程珠玑中的Javascript数组过滤方法

  1. var a = [1,2,3,4,5,6,7,8,9,10]; 
  2.  
  3.         // return everything 
  4.  
  5.         a.where( "( ) => true" ) ; 
  6.  
  7.         //  --> [1,2,3,4,5,6,7,8,9,10] 
  8.  
  9.         // return even numbers 
  10.  
  11.         a.where( "( n, i ) => n % 2 == 0" ) ; 
  12.  
  13.         //  --> [2,4,6,8,10] 
  14.  
  15.         // query first 6 products whose category begins with 'con' using extra param and regular expression 
  16.  
  17.         products.where( "( el, i, res, param ) => res.length <= 6 && param.test( el.cat )", /^con/i); 
  18.  
  19.         // using customer table data from SQL Server's northwind database...     
  20.  
  21.         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的语法检查。

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

原文链接:http://itindex.net/detail/41114-json-%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84

责任编辑:陈四芳 来源: 伯乐在线
相关推荐

2019-10-29 08:59:16

Redis底层数据

2020-08-03 07:48:15

Javascript数据结构

2020-06-28 09:57:24

数据结构算法

2020-09-18 09:13:46

数据结构元素

2020-03-04 11:10:14

数据结构程序员编译器

2020-04-02 15:37:58

数据结构存储

2023-09-06 13:16:00

数据库数据

2020-03-02 13:45:18

Redis数据结构Java

2021-07-14 23:55:18

数据结构数组

2011-03-31 15:41:51

Cacti数据表结构

2023-10-31 08:51:25

数据结构存储数据

2012-04-28 14:21:47

Java数据结构线性结构

2023-07-03 17:24:33

数据结构

2014-12-10 10:35:43

微信 数据结构

2022-11-04 08:29:05

索引数据库JSON

2023-04-11 08:00:56

Redis类型编码

2024-03-26 00:05:13

数据库数据结构

2020-10-21 14:57:04

数据结构算法图形

2021-05-12 14:09:35

链表数据结构线性结构

2023-11-12 21:49:10

Redis数据库
点赞
收藏

51CTO技术栈公众号