1. 程式人生 > >根據檔名獲取字尾並通過後綴判斷檔案格式

根據檔名獲取字尾並通過後綴判斷檔案格式

相關知識:

1、substr()的定義和用法

substr() 方法可在字串中抽取從 start 下標開始的指定數目的字元。

語法

stringObject.substr(start,length)
引數 描述
start 必需。要抽取的子串的起始下標。必須是數值。如果是負數,那麼該引數宣告從字串的尾部開始算起的位置。也就是說,-1 指字串中最後一個字元,-2 指倒數第二個字元,以此類推。
length 可選。子串中的字元數。必須是數值。如果省略了該引數,那麼返回從 stringObject
 的開始位置到結尾的字串。

返回值

一個新的字串,包含從 stringObject 的 start(包括 start 所指的字元) 處開始的 length 個字元。如果沒有指定 length,那麼返回的字串包含從 start 到 stringObject 的結尾的字元。

2、lastIndexOf()的定義和用法

lastIndexOf() 方法可返回一個指定的字串值最後出現的位置,在一個字串中的指定位置從後向前搜尋。

語法

stringObject.lastIndexOf(searchvalue,fromindex)
引數 描述
searchvalue 必需。規定需檢索的字串值。
fromindex 可選的整數引數。規定在字串中開始檢索的位置。它的合法取值是 0 到 stringObject.length - 1。如省略該引數,則將從字串的最後一個字元處開始檢索。

返回值

如果在 stringObject 中的 fromindex 位置之前存在 searchvalue,則返回的是出現的最後一個 searchvalue

 的位置。

3、toLowerCase()的定義和用法

toLowerCase() 方法用於把字串轉換為小寫。

語法

stringObject.toLowerCase()

返回值

一個新的字串,在其中 stringObject 的所有大寫字元全部被轉換為了小寫字元。

4、最後進行檔案格式的判斷時用到了linq.js

linq.js 詳細介紹(以下內容引自只為你笑的部落格)

主要特性:

實現所有 .NET 4.0 的方法

complete lazy evaluation

full IntelliSense support for VisualStudio

two versions - linq.js and jquery.linq.js (jQuery plugin)

support Windows Script Host

binding for Reactive Extensions for JavaScript(RxJS) and IntelliSense Generator -> see documentation

NuGet install support

示例程式碼:

var jsonArray = [

    { "user": { "id": 100, "screen_name": "d_linq" }, "text": "to objects" },

    { "user": { "id": 130, "screen_name": "c_bill" }, "text": "g" },

    { "user": { "id": 155, "screen_name": "b_mskk" }, "text": "kabushiki kaisha" },

    { "user": { "id": 301, "screen_name": "a_xbox" }, "text": "halo reach" }

]

// ["b_mskk:kabushiki kaisha", "c_bill:g", "d_linq:to objects"]

var queryResult = Enumerable.From(jsonArray)

    .Where(function (x) { return x.user.id < 200 })

    .OrderBy(function (x) { return x.user.screen_name })

    .Select(function (x) { return x.user.screen_name + ':' + x.text })

    .ToArray();

// shortcut! string lambda selector

var queryResult2 = Enumerable.From(jsonArray)

    .Where("$.user.id < 200")

    .OrderBy("$www.cnzhaotai.com/ .user.screen_name")

    .Select("$.user.screen_name + ':' + $.text")

    .ToArray();

/////////////////////////////////////////////////////////////////////////////////////////////////////////////////

 

用途:方便js操作查詢json資料。

下載網址:http://jslinq.codeplex.com/

使用方法:只需要引用linq.js即可。

查詢方法:

一、where查詢

var myList = [

  { Name: "Jim", www.wanmeiyuele.cn Age: 20 },

  { Name: "Kate", www.leyouzaixan.cn  Age: 21 },

  { Name: "Lilei", Age: 18 },

  { Name: "John", Age: 14 },

  { Name: "LinTao", www.yszx11.cn/  Age: 25 }

];

var arrRes = Enumerable.From(myList).Where("x=>x.Name=='Jim'").ToArray();

二、排序:OrderBy

var myList = [

  { Name: "Jim",www.baohuayule.com  Age: 20 },

  { Name: "Kate", Age: 21 },

  { Name: "Lilei",www.baohuayule.cn  Age: 18 },

  { Name: "John", Age: 14 },

  { Name: "LinTao",www.006665.cn  Age: 25 }

];

var arrRes = Enumerable.From(myList).OrderBy("x=>x.Age").ToArray();//降序OrderByDescending() 

三、去重:Distinct

var myList = [

  { Name: "Jim", Age: 20 },

  { Name: "Kate", Age: 20 },

  { Name: "Lilei", Age: 20 },

  { Name: "John", Age: 14 },

  { Name: "LinTao", Age: 25 }

];

var arrRes = Enumerable.From(myList).Distinct("x=>x.Age").ToArray(); 

四、遍歷:ForEach

var myList = [

  { Name: "Jim", Age: 20 },

  { Name: "Kate", Age: 20 },

  { Name: "Lilei", Age: 20 },

  { Name: "John", Age: 14 },

  { Name: "LinTao", Age: 25 }

   ];

   Enumerable.From(myList).ForEach(function(value, index){

        document.write("值="+value+",索引="+index);  

}); 

五、取唯一物件:First、FirstOrDefault、Last、LastOrDefault、Single、SingleOrDefault

var myList = [

  { Name: "Jim", Age: 20 },

  { Name: "Kate", Age: 20 },

  { Name: "Lilei", Age: 20 },

  { Name: "John", Age: 14 },

  { Name: "LinTao", Age: 25 }

];

var arrRes = Enumerable.From(myList).FirstOrDefault("x=>x.Age>18");

六、Skip、Take

Enumerable.Range(1,10).Skip(5)//結果[6,7,8,9,10]

Enumerable.Range(1,10).Take(5)//結果[1,2,3,4,5]