安云网 - AnYun.ORG | 专注于网络信息收集、网络数据分享、网络安全研究、网络各种猎奇八卦。
当前位置: 安云网 > 技术关注 > 编程茶楼 > 脚本语言 > 查询json数据结构的8种方式

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

时间:2015-02-18来源: 作者:点击:
查询json数据结构的8种方式

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

//内容来自AnYun.ORG

  JsonSQL //内容来自AnYun.ORG

  JsonSQL实现了使用SQL select语句在json数据结构中查询的功能。 //内容来自AnYun.ORG

  例子:

//内容来自AnYun.ORG

jsonsql.query("select * from json.channel.items order by title desc",json); 
//内容来自安云网

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

//内容来自AnYun.ORG

  JSONPath

//内容来自安云网

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

//内容来自AnYun.ORG

  例子: //内容来自安云网

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

//内容来自AnYun.ORG

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

//内容来自AnYun.ORG

  TaffyDB //本文来自安云网

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

//内容来自AnYun.ORG

var kelly = friends({id:2}).first(); //内容来自安云网 

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

//本文来自安云网

  linq.js //内容来自AnYun.ORG

  linq.js——Javascript中的LINQ(译者注:.Net中的概念,见http://msdn.microsoft.com/zh-tw/library/bb397897//内容来自AnYun.ORG

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'] //内容来自AnYun.ORG 

  主页:https://github.com/agilosoftware/objeq //内容来自AnYun.ORG

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

//内容来自安云网

  json:select() //本文来自安云网

  使用类CSS选择符来查询JSON。 //内容来自AnYun.ORG

.lang:val("Bulgarian") ~ .level //内容来自AnYun.ORG 

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

//本文来自安云网

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

//内容来自AnYun.ORG

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/

//内容来自AnYun.ORG

QQ群: WEB开发者官方总群(196171896) 验证消息:Admin10000
顶一下
(0)
0%
踩一下
(0)
0%
------分隔线----------------------------
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
验证码: 点击我更换图片
相关内容
推荐内容