根據檔名獲取字尾並通過後綴判斷檔案格式
相關知識:
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]