今天正在看The Art and Science of JavaScript,突然想到javascript裡也應該有關於LINQ的實現,於是Google了一下,果然發現LINQ to JavaScript這個OpenSource Project。
介紹
LINQ to JavaScript (JSLINQ) 是LINQ在JavaScript上的實現。其為JS的Array對象上增加了一系列擴充方法。如果你要用到Array,那麼你就可以使用JSLINQ。
如果你還不瞭解什麼是LINQ;LINQ是.NET Framework 3.5支援的新特性,其可以允許像SQL查詢一樣操作各種類型的資料。LINQ to JavaScript就是專門為數組提供查詢的能力。
用法樣本
var myList = [
{FirstName:"Chris",LastName:"Pearson"},
{FirstName:"Kate",LastName:"Johnson"},
{FirstName:"Josh",LastName:"Sutherland"},
{FirstName:"John",LastName:"Ronald"},
{FirstName:"Steve",LastName:"Pinkerton"}
];
var exampleArray = From(myList).
Where("item.FirstName == 'Chris'").
OrderBy("item.FirstName").
Select("item.FirstName");
使用LINQ to JavaScript
我們使用下面的數組來作為例子示範:var myList = [
{FirstName:"Chris",LastName:"Pearson"},
{FirstName:"Kate",LastName:"Johnson"},
{FirstName:"Josh",LastName:"Sutherland"},
{FirstName:"John",LastName:"Ronald"},
{FirstName:"Steve",LastName:"Pinkerton"}
];
就像在.NET中一樣的使用From操作符
From操作符不是必須的,寫上的話可以使得看上去更像LINQ的文法。
var example = From(myList);
使用Where操作符來限定查詢條件
如下所示,我們會得到數組裡全部屬性FirstName值為Chris的對象。
// 傳入的是查詢運算式
var whereExample1 = From(myList).
Where("item.FirstName == 'Chris'");
// 傳入的是查詢函數方法
var whereExample2 = From(myList).
Where(function(item){return item.FirstName == 'Chris';});
使用Select操作符來指定返回的資料
如下所示,我們會得到數組裡的每個元素的FirstName屬性。
// 傳入的是查詢運算式
var selectTest1 = From(myList).
Select("item.FirstName");
// 傳入的是查詢函數方法
var selectTest2 = From(myList).
Select(function(item){return item.FirstName;});
使用OrderBy操作符來決定怎樣對數組中的元素進行排序
如下所示,我們會得到按FirstName屬性排序後的數組。// 傳入的是查詢運算式
var sortTest1 = From(myList).
OrderBy("item.FirstName");
// 傳入的是查詢函數方法
var sortTest1 = From(myList).
OrderBy(function(item){return item.FirstName});
HomePage: http://www.codeplex.com/JSLINQ
Download: http://files.cnblogs.com/Icebird/JSLINQ_withSDK_v1.03.rar (2008-02-10)