Last week, I wanted to call an oData service from my HTML5 metro app. First I was planning to use datajs until I discovered JayData which offers similar functionality to datajs and much more!
JayData provides JavaScript Language Query (JSLQ) as a tool to query local (in-browser and mobile) and remote data sources with a simple, unified query syntax: JavaScript itself. Much like Microsoft .NET developers can utilize LINQ to perform operations on data from different databases.
The aim of JayData library is to give a similar level of abstraction with the help of the $data.Expressions API and the JavaScript language itself.
JayData is cross-platform (runs on HTML5 desktop and mobile browsers, can be hosted in PhoneGap environment on iPhone, iPad and Android) and cross-layer as it works on client-side and server-side (Node.JS).
It provides support for
A northwind.js file is generated.
Include this file into your web page together with jaydata.js and jQuery.
Now you can write some Javascript that uses this northwind odata service:
That’s all!
What’s JayData?
JayData is a standards-based, cross-platform Javascript library and a set of practices to access and manipulate data from various online and offline sources.JayData provides JavaScript Language Query (JSLQ) as a tool to query local (in-browser and mobile) and remote data sources with a simple, unified query syntax: JavaScript itself. Much like Microsoft .NET developers can utilize LINQ to perform operations on data from different databases.
The aim of JayData library is to give a similar level of abstraction with the help of the $data.Expressions API and the JavaScript language itself.
JayData is cross-platform (runs on HTML5 desktop and mobile browsers, can be hosted in PhoneGap environment on iPhone, iPad and Android) and cross-layer as it works on client-side and server-side (Node.JS).
It provides support for
- WebSQL
- SQLite
- IndexedDB
- OData
- YQL
How to start using it(in ASP.NET)?
- Create a new web application
- Add the JayData nuget package.
- A command line utility is copied into the web folder. With that you can create a JayData client context from any oData metadata document.
C:\NorthWindSample>JaySvcUtil.exe -m http://services.odata.org/Northwind/Northwind.svc/$metadata
–n northwind -o northwind.js
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <script type="text/javascript" src="/scripts/jquery-1.7.1.min.js"></script> <script type="text/javascript" src="/scripts/JayData.js"></script> <script type="text/javascript" src="northwind.js"></script> <script> var nwcontext = new northwind.NorthwindEntities({ name: 'oData', oDataServiceHost: 'http://services.odata.org/Northwind/Northwind.svc' }); function createItemLI(name, id, css) { var li = $('<li></li>').append(name).addClass(css).data('id', id); return li; } $(function () { nwcontext.Categories.toArray(function (categories) { categories.forEach(function (category) { $('#categories').append( createItemLI(category.Category_Name, category.Category_ID, 'category')); }); }); }); </script> </head> <body> <ul id="categories"> </ul> </body>