文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

查询json数据结构的方式有哪些

2024-04-02 19:55

关注

这篇文章主要介绍“查询json数据结构的方式有哪些”,在日常操作中,相信很多人在查询json数据结构的方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”查询json数据结构的方式有哪些”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

你有没有对“在复杂的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的语法检查。

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

到此,关于“查询json数据结构的方式有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯