摘要:元素是通過指定的分隔符進行分隔的。返回值如果從中刪除了元素,則返回的是含有被刪除的元素的數(shù)組。根據(jù)使用的方法不同,這個函數(shù)執(zhí)行后的返回值可能會也可能不會影響訪問的返回值。對數(shù)組中的每一項運行給定函數(shù),返回該函數(shù)會返回的項組成的數(shù)組。
Object類型
創(chuàng)建object實例方法有兩種。第一種方法使用new操作符后跟object構(gòu)造函數(shù)。如下:
var person=new Object(); person.name="Nicholas"; person.age=29;
第二種方法使用對象字面量表示法。如下:
var person={ name:"Nicholas", age:29 }Array類型 檢測數(shù)組
使用instanceof操作符:
if(value instanceof Array){ //對數(shù)組執(zhí)行某些操作 }
ECMAScript5新增加Array.isArray()方法。這個方法的目的是最終確定某個值到底是不是數(shù)組,而不管它是在哪個全局執(zhí)行環(huán)境中創(chuàng)建的。這個方法如下:
if(Array.isArray(value)){ //對數(shù)組執(zhí)行某些操作 }
IE9+及以上,其它主流瀏覽器兼容。
轉(zhuǎn)換方法toLocaleString()方法
toString()方法
valueOf()方法
join()方法
所有對象都具有toLocaleString()、toString()、valueOf()方法。其中調(diào)用數(shù)組的toString方法會返回以數(shù)組中的每個值的字符串形式拼接而成的一個以逗號分割的字符串。
而調(diào)用valueOf()方法返回的還是數(shù)組。
var colors = ["red","blue","green"]; console.log(colors.toString()); console.log(colors.valueOf()); console.log(colors.toLocaleString());
得到的結(jié)果如圖所示:
另外toLocaleString()方法經(jīng)常會返回跟toString()和valueOf()方法相同的值。但也不是總?cè)绱?。當調(diào)用數(shù)組的toLocaleString()方法時,它也會創(chuàng)建一個數(shù)組值的以逗號分割的字符串。而與前兩個方法唯一不同的是,這一次為了取得每一項的值,調(diào)用的每一項的toLocaleString()方法,而不是toString()方法。如下面例子:
var person1 = { toLocaleString: function(){ return "Nikolaos"; }, toString: function(){ return "Nicholaos"; } } var person2 = { toLocaleString: function(){ return "Grigorios"; }, toString: function(){ return "Greg"; } } var person = [person1,person2]; alert(person); //Nicholaos,Greg alert(person.toString()); //Nicholaos,Greg alert(person.toLocaleString());//Nikolaos,Grigorios
說明:由于alert()要接收字符串參數(shù),所以它會在后臺調(diào)用toString()方法,得到跟直接調(diào)用toString()方法一樣的結(jié)果。
數(shù)組繼承的toLocaleString()、toString()、valueOf()方法,在默認情況下都會以逗號分割的字符串的形式返回數(shù)組項??梢允褂胘oin()方法,則可以使用不同的分隔符來構(gòu)建這個字符串。
join()方法
join() 方法用于把數(shù)組中的所有元素放入一個字符串。元素是通過指定的分隔符進行分隔的。返回一個字符串。
var colors = ["red","blue","green"]; console.log(colors.join(",")); //red,blue,green console.log(colors.join("||")); //red||blue||green棧方法(后進先出)
棧是一種LIFO(Last-In-First-Out,后進先出)的數(shù)據(jù)結(jié)構(gòu),也就是最新添加的元素最早被移除。
ArrayObj.push()方法
ArrayObj.pop()方法
ArrayObj.push():就是向數(shù)組末尾添加新的元素,返回的是數(shù)組新的長度。
ArrayObj.pop():就是向數(shù)組中刪除數(shù)組最后一個元素并且返回該元素。如果數(shù)組為空就返回undefined。
ArrayObj.shift()
ArrayObj.unshift()
ArrayObj.shift():方法用于把數(shù)組中的第一個元素刪除,并返回第一個元素的值。
如果數(shù)組是空的,則shift() 方法不進行任何操作,返回undefined。請注意,該方法不創(chuàng)建新數(shù)組,而是直接修改原來的數(shù)組。該方法會改變數(shù)組的長度。
ArrayObj.unshift() :該方法可把它的參數(shù)順序添加到數(shù)組的頭部。它直接修改了數(shù)組,而不是創(chuàng)建一個新的數(shù)組。返回的是新數(shù)組的長度。
unshift()在IE6,IE7下,數(shù)據(jù)有添加成功,但返回值卻是undefined。
重排序方法reverse()方法
sort()方法
reverse()方法會對反轉(zhuǎn)數(shù)組項的順序。
var values = [1, 2, 3, 4, 5]; values.reverse(); alert(values); //5,4,3,2,1
這里數(shù)組的初始值及順序是1、2、3、4、5。而調(diào)用數(shù)組的reverse()方法后,其值的順序變成了5、4、3、2、1。
sort()方法按升序排列數(shù)組——即最小的值位于最前面,最大的值排在最后面。為了實現(xiàn)排序,sort()方法會調(diào)用每個數(shù)組項的toString()轉(zhuǎn)型方法,然后比較得到字符串,以確定如何排序。即使數(shù)組中的每一項都是數(shù)組,sort()方法比較的也是字符串,如下所示:
var values = [0, 1, 5, 10, 15]; values.sort(); alert(values); //0,1,10,15,5
這種排序方式在很多情況下都不是最佳方案。因此sort()方法可以接受一個比較函數(shù)作為參數(shù),以便我們指定那個值位于那個值的前面。
比較函數(shù)接受兩個參數(shù),如果第一個參數(shù)應(yīng)該位于第二個之前則返回一個負數(shù),如果兩個參數(shù)相等,則返回0,如果第一個參數(shù)位于第二個之后則返回一個正數(shù)。以下就是一個簡單的比較函數(shù):
function compare(value1, value2) { if (value1 < value2) { return -1; } else if (value1 > value2) { return 1; } else { return 0; } }
這個比較函數(shù)可以使用于大多數(shù)數(shù)據(jù)類型,只要將其作為參數(shù)傳遞給sort()方法即可,如下面這個例子所示:
var values = [0, 1, 2, 5, 10, 15]; values.sort(compare); alert(values); //0,1,5,10,15
在將比較函數(shù)傳遞到sort()方法之后,數(shù)值仍然保持了正確的升序。當然,也可以通過比較函數(shù)產(chǎn)生降序排序的結(jié)果,只要交換比較函數(shù)返回的值即可:
function compare(value1, value2) { if (value1 < value2) { return 1; } else if (value1 > value2) { return -1; } else { return 0; } } var values = [0, 1, 2, 5, 10, 15]; values.sort(compare); alert(values); //15,10,5,1,0
reverse()和sort()方法會返回值是經(jīng)過排序之后的數(shù)組。
對于數(shù)值類型或者其valueOf方法會返回數(shù)值類型的對象類型,可以使用一個更簡單的比較函數(shù)。這個函數(shù)只要用第二個值減第一個值即可:
function compare(value1, value2) { return value2 - value1; }
由于比較函數(shù)通過返回一個小于零、等于零或大于零的值來影響排序結(jié)果,因此減法操作就可以適當處理所有情況。
操作方法concat()方法
slice()方法
splice()方法
concat() 方法用于連接兩個或多個數(shù)組。
該方法不會改變現(xiàn)有的數(shù)組,而僅僅會返回被連接數(shù)組的一個副本。
輸出的結(jié)果:1,2,3,4,5
簡介slice()與splice()方法
slice(start,end)方法
start 必需。規(guī)定從何處開始選取。如果是負數(shù),那么它規(guī)定從數(shù)組尾部開始算起的位置。也就是說,-1 指最后一個元素,-2 指倒數(shù)第二個元素,以此類推。
end 可選。規(guī)定從何處結(jié)束選取。該參數(shù)是數(shù)組片斷結(jié)束處的數(shù)組下標。如果沒有指定該參數(shù),那么切分的數(shù)組包含從 start 到數(shù)組結(jié)束的所有元素。如果這個參數(shù)是負數(shù),那么它規(guī)定的是從數(shù)組尾部開始算起的元素。
返回值:返回一個新的數(shù)組,包含從 start 到 end (不包括該元素)的 arrayObject 中的元素。
splice() 方法用于插入、刪除或替換數(shù)組的元素
語法:arrayObject.splice(index,howmany,element1,.....,elementX)
index 必需。規(guī)定從何處添加/刪除元素。
該參數(shù)是開始插入和(或)刪除的數(shù)組元素的下標,必須是數(shù)字。
howmany 必需。規(guī)定應(yīng)該刪除多少元素。必須是數(shù)字,但可以是 "0"。
如果未規(guī)定此參數(shù),則刪除從 index 開始到原數(shù)組結(jié)尾的所有元素。
element1 可選。規(guī)定要添加到數(shù)組的新元素。從 index 所指的下標處開始插入。
elementX 可選。可向數(shù)組添加若干元素。
返回值:如果從 arrayObject 中刪除了元素,則返回的是含有被刪除的元素的數(shù)組。
說明:splice() 方法可刪除從 index 處開始的零個或多個元素,并且用參數(shù)列表中聲明的一個或多個值來替換那些被刪除的元素。
下面簡要概括一下slice()與splice()方法
slice(start, end); slice()方法返回從參數(shù)指定位置開始到當前數(shù)組末尾的所有項。如果有兩個參數(shù),該方法返回起死和結(jié)束位置之間的項,但不包括結(jié)束位置的項。
var colors = ["red", "green", "blue", "yellow", "purple"]; var colors2 = colors.slice(1); var colors3 = colors.slice(1,4); console.log(colors2); // green, blue, yellow, purple console.log(colors3); // green, blue, yellow
splice()有刪除,插入,替換的功能
刪除 - 需要兩個參數(shù),要刪除的第一項的位置和要刪除的項數(shù)。
var colors = ["red", "green", "blue"]; var removed = colors.splice(0,1); console.log(colors); // greeen, blue console.log(removed); // red
插入 - 需要三個參數(shù):起始位置、0(要刪除的項數(shù))和要插入的項
var colors = ["red", "green", "blue"]; var removed = colors.splice(1,0,"yellow", "orange"); console.log(colors); // ["red", "yellow", "orange", "green", "blue"] console.log(removed); // 返回空
替換 - 需要三個參數(shù):起始位置、要刪除的項數(shù)和要插入的任意數(shù)量的項。
var colors = ["red", "green", "blue"]; var removed = colors.splice(1,1,"yellow", "orange"); console.log(colors); // ["red", "yellow", "orange", "blue"] console.log(removed); // ["green"]位置方法
indexOf()方法
lastIndexOf()方法
ECMAScript5為數(shù)組實例添加了兩個位置方法:indexOf()和lastIndexOf()。這兩個方法都接收兩個參數(shù):要查找的項和(可選的)表示查找起點位置的索引。其中indexOf()方法從數(shù)組開頭(位置0)開始向后查找,lastIndexOf()方法則從數(shù)組的末尾開始向前查找。
這兩個方法都返回查找的項在數(shù)組中的位置,或者沒有查找到的情況下返回-1。在比較第一個參數(shù)與數(shù)組中的每一項時,會使用全等操作符;也就是說要求查找的項必須嚴格相等(就像使用===一樣)。
var numbers = [1,2,3,4,5,4,3,2,1]; console.log(numbers.indexOf(4));//3 console.log(numbers.lastIndexOf(4));//5 console.log(numbers.indexOf(4,4)); //5 console.log(numbers.lastIndexOf(4,4));//3 var person = {name:"Niccholas"}; var people = [{name:"Niccholas"}]; var morePeople = [person]; console.log(people.indexOf(person));//-1 console.log(morePeople.indexOf(person)); //0
支持的瀏覽器IE9+,F(xiàn)ireFox2+,Safari3+,Opera9.5+和Chrome。
迭代方法ECMAScript5為數(shù)組定義了5個迭代方法。每個方法都接收兩個參數(shù):要在每一項上運行的函數(shù)和(可選的)運行該函數(shù)的作用域?qū)ο蟆绊憈his的值。傳入這些方法的函數(shù)會接收三個參數(shù):數(shù)組項的值、該項在數(shù)組中的位置和數(shù)組對象本身。根據(jù)使用的方法不同,這個函數(shù)執(zhí)行后的返回值可能會也可能不會影響訪問的返回值。
every():對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對每一項都返回true,則返回true。
filter():對數(shù)組中的每一項運行給定函數(shù),返回該函數(shù)會返回true的項組成的數(shù)組。
forEach():對數(shù)組中的每一項運行給定函數(shù),這個方法沒有返回值。
map():對數(shù)組中的每一項運行給定函數(shù),返回每次函數(shù)調(diào)用的結(jié)果組成的數(shù)組。
some():對數(shù)組中的每一項運行給定函數(shù),如果該函數(shù)對某一項返回true,則返回true。
以上方法都不會修改數(shù)組中的包含的值。
在這些方法中最相似的是every()和`some(),他們都用于查詢數(shù)組中的某一項是否滿足某個條件。
var numbers = [1,2,3,4,5,4,3,2,1]; var everyResult = numbers.every(function(item,index,array){ return (item > 2); }); console.log(everyResult); //false var someResult = numbers.some(function(item,index,array){ return (item > 2); }); console.log(someResult); //true
filter():
var numbers = [1,2,3,4,5,4,3,2,1]; var filterResult = numbers.filter(function(item,index,array){ return (item > 2); }); console.log(filterResult); //[3, 4, 5, 4, 3]
map():
var numbers = [1,2,3,4,5,4,3,2,1]; var mapResult = numbers.map(function(item,index,array){ return (item * 2); }); console.log(mapResult); //[2, 4, 6, 8, 10, 8, 6, 4, 2]
forEach():這個方法沒有返回值,本質(zhì)上和使用for循環(huán)迭代數(shù)組一樣。
支持的瀏覽器IE9+,F(xiàn)ireFox2+,Safari3+,Opera9.5+和Chrome。
縮小方法ECMAScript5還新增了兩個縮小數(shù)組的方法。reduce()和reduceRight()方法。這兩個方法都會迭代數(shù)組的所有項,然后構(gòu)建一個最終返回的值。其中reduce()方法從數(shù)組中的第一項開始,逐個遍歷到最后。而reduceRight()則從數(shù)組的最后一項開始,向前遍歷到第一項。
這兩個方法都接收兩個參數(shù):一個在每一項上調(diào)用的函數(shù)和(可選)作為縮小基礎(chǔ)的初始值。傳給reduce()和reduceRight()的函數(shù)接收四個參數(shù):前一個值、當前值、項的所有、數(shù)組對象。這個函數(shù)返回的任何值都會作為第一個參數(shù)自動傳給下一項。第一次迭代放生在數(shù)組的第二項上,因此第一個參數(shù)是數(shù)組的第一項,第二個參數(shù)是數(shù)組的第二項。
使用reduce()方法可以執(zhí)行求數(shù)組中所有值之和的操作,比如:
var values = [1,2,3,4,5]; var sum = values.reduce(function(pre,cur,index,array){ return pre + cur; }); console.log(sum); //15
reduceRight()方法相似,只是方法想法而已。
支持的瀏覽器IE9+,F(xiàn)ireFox2+,Safari3+,Opera9.5+和Chrome。
Date類型要創(chuàng)建一個日期對象,使用new操作符和Date構(gòu)造函數(shù)即可:
var now = new Date();
Date.parse()方法
其中Date.parse()方法接收一個表示日期的字符串參數(shù),然后嘗試根據(jù)這個字符串返回相應(yīng)日期的毫秒數(shù)。ECMA-262沒有定義Date.parse()應(yīng)該支持哪種日期格式,因此這個方法的行為因?qū)崿F(xiàn)而異,而且通常是因地區(qū)而異。將地區(qū)設(shè)置為美國的瀏覽器通常都接受下列日期格式:
"月/日/年",如6/13/2004;
"英文月名 日,年",如May 12,2004;
"英文星期幾 英文月名 日 年 時:分:秒 時區(qū)",如Tue May 25 2004 00:00:00 GMT+0800。
ISO 8601擴展格式Y(jié)YYY-MM-DDTHH:mm:ss:sssZ(例如 2004-05-25T00::00:00)。只有兼容ECMAScript5的實現(xiàn)支持這種格式。
例如,要為2004年5月25日創(chuàng)建一個日期對象,可以使用下面的代碼:
//Tue May 25 2004 00:00:00 GMT+0800 (中國標準時間) var someDate = new Date(Date.parse("May 25,2004"));
如果傳入Data.parse()的方法的字符串 不能表示日期格式,會返回NAN。實際上,如果直接將表示日期的字符串傳遞給Date構(gòu)造函數(shù),也會在后臺調(diào)用Date.parse()方法,例如下面的代碼跟前面的是等價的。
//Tue May 25 2004 00:00:00 GMT+0800 (中國標準時間) var someDate = new Date("May 25,2004");
這行代碼將會得到與前面一行相同的日期對象。
Date.UTC()方法
Date.UTC()同樣返回日期的毫秒數(shù)。但它與Date.parse()在構(gòu)建值時使用的是不同的信息。Date.UTC()的參數(shù)分別表示年份、基于0的月數(shù)(一月是0,二月是1,依次類推)、月中的哪一天(1到31)、小時數(shù)(0到23)、分鐘、秒、毫秒數(shù)。在這些參數(shù)中只有前兩個參數(shù)是必須的(年和月)。如果沒有提供月中的天數(shù),則假設(shè)天數(shù)為1;如果省略其它參數(shù),則統(tǒng)統(tǒng)假設(shè)為0,如下例子:
//GMT時間2000年1月1日午夜零時 var y2k = new Date(Date.UTC(2000,0)); console.log(y2k); //Sat Jan 01 2000 08:00:00 GMT+0800 (中國標準時間) //GMT時間2005年5月5日下午5:55:55 var allFives = new Date(Date.UTC(2005,4,5,17,55,55)); console.log(allFives);//Fri May 06 2005 01:55:55 GMT+0800 (中國標準時間)
說明下:Greenwich Mean Time (GMT)格林尼治標準時間英國、愛爾蘭、冰島和葡萄牙屬于該時區(qū)。這個時區(qū)與中國北京時間的時差是8個小時,也就是說比北京時間晚8個小時。
Date構(gòu)造函數(shù)
Date構(gòu)造函數(shù)會模仿Date.UTC(),但有一點 不同的是,日期和時間都是基于本地時區(qū)而非GMT來創(chuàng)建。不過他們的參數(shù)跟Date.UTC()的參數(shù)一樣。
例如:
//本地時間2000年1月1日午夜零時 var y2k = new Date(2000,0); console.log(y2k); //Sat Jan 01 2000 00:00:00 GMT+0800 (中國標準時間) //本地時間2005年5月5日下午5:55:55 var allFives = new Date(2005,4,5,17,55,55); console.log(allFives);//Thu May 05 2005 17:55:55 GMT+0800 (中國標準時間)
Date.now()方法
ES5添加了Date.now()方法,返回表示這個方法時的日期和時間的毫秒數(shù)。這個方法簡化了使用Date對象分析代碼的工作,例如:
//取得開始時間 var start = Date.now(); //調(diào)用函數(shù) dosomething(); //取得結(jié)束時間 var stop = Date.now(), result = stop - start; console.log(start,stop,result); //1494292306763 1494292306768 5 function dosomething(){ console.log("打印結(jié)果"); }
支持Date.now()方法的瀏覽器包括IE9+,F(xiàn)ireFox3+,Safari3+,Opera10.5+和Chrome。在不支持的其它瀏覽器,使用+操作符把Date對象轉(zhuǎn)成字符串,也可以達到相同的目的。
//取得開始時間 var start = +new Date(); //調(diào)用函數(shù) dosomething(); //取得結(jié)束時間 var stop = +new Date(), result = stop - start; console.log(start,stop,result); //1494292306763 1494292306768 5 function dosomething(){ console.log("打印結(jié)果"); }繼承的方法
與其它引用類型一樣,Date類型也重寫了toLocaleString()、toString()和valueOf()方法。
其中toLocaleString()、toString()在顯示日期和時間沒有什么價值;而valueOf()方法不是返回的字符串,而是返回日期的毫秒表示。因此可以方便使用比較操作符(大于或小于)來比較日期值。如下面的例子:
var date1 = new Date(2007,0,1); var date2 = new Date(2007,1,1); console.log(date1 < date2); //true console.log(date1 > date2); //false日期格式化方法
Date類型還有一些專門用于將日期格式化為字符串的方法,如下:
toDateString()——以特定于實現(xiàn)的格式顯示星期幾、月、日和年;
toTimeString()——以特定于實現(xiàn)的格式顯示時、分、秒和時區(qū);
toLocaleDateString()——以特定與地區(qū)的格式顯示星期幾、月、日和年;
toLocaleTimeString()——以特定于實現(xiàn)的格式顯示時、分、秒;
toUTCString()——以特定于實現(xiàn)的格式完整的UTC日期。
與toLocaleString()和toString()方法一樣,以上這些字符串格式的方法輸出也是因瀏覽器而異的。因此沒有哪一個方法能夠用來在用戶界面上顯示一致的日期信息。
日期/時間組件方法Date() 返回當日的日期和時間。
getDate() 從 Date 對象返回一個月中的某一天 (1 ~ 31)。
getDay() 從 Date 對象返回一周中的某一天 (0 ~ 6)。
getMonth() 從 Date 對象返回月份 (0 ~ 11)。
getFullYear() 從 Date 對象以四位數(shù)字返回年份。
getYear() 請使用 getFullYear() 方法代替。
getHours() 返回 Date 對象的小時 (0 ~ 23)。
getMinutes() 返回 Date 對象的分鐘 (0 ~ 59)。
getSeconds() 返回 Date 對象的秒數(shù) (0 ~ 59)。
getMilliseconds() 返回 Date 對象的毫秒(0 ~ 999)。
getTime() 返回 1970 年 1 月 1 日至今的毫秒數(shù)。
getTimezoneOffset() 返回本地時間與格林威治標準時間 (GMT) 的分鐘差。
getUTCDate() 根據(jù)世界時從 Date 對象返回月中的一天 (1 ~ 31)。
getUTCDay() 根據(jù)世界時從 Date 對象返回周中的一天 (0 ~ 6)。
getUTCMonth() 根據(jù)世界時從 Date 對象返回月份 (0 ~ 11)。
getUTCFullYear() 根據(jù)世界時從 Date 對象返回四位數(shù)的年份。
getUTCHours() 根據(jù)世界時返回 Date 對象的小時 (0 ~ 23)。
getUTCMinutes() 根據(jù)世界時返回 Date 對象的分鐘 (0 ~ 59)。
getUTCSeconds() 根據(jù)世界時返回 Date 對象的秒鐘 (0 ~ 59)。
getUTCMilliseconds() 根據(jù)世界時返回 Date 對象的毫秒(0 ~ 999)。
setDate() 設(shè)置 Date 對象中月的某一天 (1 ~ 31)。
setMonth() 設(shè)置 Date 對象中月份 (0 ~ 11)。
setFullYear() 設(shè)置 Date 對象中的年份(四位數(shù)字)。
setYear() 請使用 setFullYear() 方法代替。
setHours() 設(shè)置 Date 對象中的小時 (0 ~ 23)。
setMinutes() 設(shè)置 Date 對象中的分鐘 (0 ~ 59)。
setSeconds() 設(shè)置 Date 對象中的秒鐘 (0 ~ 59)。
setMilliseconds() 設(shè)置 Date 對象中的毫秒 (0 ~ 999)。
setTime() 以毫秒設(shè)置 Date 對象。
setUTCDate() 根據(jù)世界時設(shè)置 Date 對象中月份的一天 (1 ~ 31)。
setUTCMonth() 根據(jù)世界時設(shè)置 Date 對象中的月份 (0 ~ 11)。
setUTCFullYear() 根據(jù)世界時設(shè)置 Date 對象中的年份(四位數(shù)字)。
setUTCHours() 根據(jù)世界時設(shè)置 Date 對象中的小時 (0 ~ 23)。
setUTCMinutes() 根據(jù)世界時設(shè)置 Date 對象中的分鐘 (0 ~ 59)。
setUTCSeconds() 根據(jù)世界時設(shè)置 Date 對象中的秒鐘 (0 ~ 59)。
setUTCMilliseconds() 根據(jù)世界時設(shè)置 Date 對象中的毫秒 (0 ~ 999)。
ECMAScript通過RegExp類型支持正則表達式,如下:
var expression = /pattern/flags;
其中的模式(pattern)部分可以是任何簡單或者復(fù)雜的正則表達式,可以包含字符類、限定符、分組、向前查找以及反向引用。每個正則表達式可帶有一個或者多個標注(flags),用以標明正則表達式的行為。有三個以下標志:
g:表示全局模式,即模式將被應(yīng)用到所有字符串,而非在發(fā)現(xiàn)第一個匹配項時立即停止。
i:表示不區(qū)分大小寫模式。
m:表示多行模式,即在到達一行文本末尾時還在繼續(xù)查找下一行中是否存在于模式匹配的項。
以字面量的形式來定義正則表達式
例如:匹配第一個bat或者cat,不區(qū)分大小寫
var pattern = /[bc]at/i;
使用RegExp構(gòu)造函數(shù)
它接收兩個參數(shù):一個是要匹配的字符串模式,另一個是可選的標志字符串??梢允褂米置媪慷x的任何表達式,都可以使用構(gòu)造函數(shù)來定義,還是以上面的例子為例:
var pattern = new RegExp("[bc]at","i");
注意:RegExp構(gòu)造函數(shù)模式參數(shù)時字符串,所以再某些情況下要對字符進項雙重轉(zhuǎn)義。所有元字符都必須雙重轉(zhuǎn)義,如字面量模式為/[bc]at/,那么等價的字符串為"/[bc]at/"
例子:
var re = null, i; for(i=0; i < 10; i++){ re = /cat/g; console.log(re.test("catastrophe")); } for(i=0; i < 10; i++){ re = new RegExp("cat","g"); console.log(re.test("catastrophe")); }
打印結(jié)果都為10個true
RegExp實例方法
exec - exec接收一個參數(shù),即要應(yīng)用模式的字符串,然后返回包含第一個匹配信息的數(shù)組。
var text = "cat, bat, sat, fat"; var pattern1 = /.at/; var matches = pattern1.exec(text); console.log(matches); // ["cat"]
match - match是字符串執(zhí)行匹配正則表達式規(guī)則的方法,他的參數(shù)是正則表達
var text = "cat, bat, sat, fat"; var pattern1 = /.at/; var matches2 = text.match(pattern1); console.log(matches2); // ["cat"]
test - test()接收一個字符串參數(shù)
var text = "000-00-0000"; var pattern = /d{3}-d{2}-d{4}/; if (pattern.test(text)){ console.log("The pattern was matched"); // The pattern was matched }
詳細解釋可查看《js學(xué)習(xí)筆記 - 正則表達式詳解》
Function類型由于函數(shù)名僅僅是指向函數(shù)的指針。因此函數(shù)名與包含對象指針的其它變量沒有什么不同。換句話說,一個函數(shù)可能有多個名字,如下例子:
function sum(num1,num2){ return num1 + num2; } console.log(sum(10,10)); //20 var anotherSum = sum; console.log(anotherSum(10,10)); //20 sum = null; console.log(anotherSum(10,10)); //20
沒有重載(深入理解) 函數(shù)聲明與函數(shù)表達式 作為值的函數(shù) 函數(shù)內(nèi)部屬性注意:使用不帶圓括號的函數(shù)名是訪問函數(shù)指針,而非調(diào)用函數(shù)。
在函數(shù)內(nèi)部有兩個特殊的對象:arguments和this。
把arguments轉(zhuǎn)為數(shù)組
(function() { var slice = Array.prototype.slice, aArguments = slice.apply(arguments); console.log(aArguments); })(10, 20, 30);
arguments.callee
該屬性是一個指針,指向擁有這個arguments對象的函數(shù)。當函數(shù)在嚴格模式下運行時,訪問arguments.callee會導(dǎo)致錯誤。
this
window.color = "red"; var o = {color:"blue"}; function sayColor(){ console.log(this.color); } sayColor(); // red sayColor.call(this); // red sayColor.call(window); // red sayColor.call(o); // blue函數(shù)屬性和方法
length
length屬性表示函數(shù)希望接收的命名參數(shù)的個數(shù)。
function sayName(name){ alert(name); } function sum(num1,num2){ return num1 + num2; } function sayHi(){ alert("hi"); } console.log(sayName.length); //1 console.log(sum.length); //2 console.log(sayHi.length); //0
prototype
在es5中prototype屬性是不可枚舉的,因此使用for-in無法發(fā)現(xiàn)。
每個函數(shù)都包含兩個非繼承而來的方法:call()和apply()。他們的區(qū)別在于接收的參數(shù)方式不同。
function sum(num1, num2){ return num1 + num2; } function callSum1(num1,num2){ return sum.apply(this,arguments); } function callSum2(num1, num2){ return sum.apply(this, [num1, num2]); } console.log(callSum1(10,10)); // 20 console.log(callSum2(10,10)); //20
傳遞參數(shù)并非apply()和call()的用武之地,它們的強大之處在于擴充函數(shù)的作用域,如下例子:
window.color = "red"; var o = {color:"blue"}; function sayColor(){ console.log(this.color); } sayColor(); //red sayColor.call(this); //red sayColor.call(window); //red sayColor.call(o); //blue
es5還定義了一個方法:bind()方法,這個方法會創(chuàng)建一個函數(shù)的實例,其中this會被綁定到傳給bind()函數(shù)的值。
window.color = "red"; var o = {color:"blue"}; function sayColor(){ console.log(this.color); } var objectSayColor = sayColor.bind(o); objectSayColor(); //blue
sayColor調(diào)用bind()并傳入o對象,創(chuàng)建了objectSayColor()函數(shù),objectSayColor()函數(shù)的this值等于o。
因此即使是在全局作用域中調(diào)用這個函數(shù),結(jié)果也是blue。
基本包裝類型var value = "25"; var number = Number(value); console.log(typeof number); console.log(number instanceof Number);// false var obj = new Number(value); console.log(typeof obj); console.log(obj instanceof Number);// trueBoolean類型
var falseObject = new Boolean(false); var result = falseObject && true; // true //布爾表達式中的所有對象都會被轉(zhuǎn)換為true, 因此falseObject對象在布爾表達式中代表的是true console.log(result); // true var falseValue = false; result = falseValue && true; console.log(result); //false console.log(typeof falseObject); //object console.log(typeof falseValue); // Boolean console.log(falseObject instanceof Boolean); //true console.log(falseValue instanceof Boolean); // falseNumber類型
var numberObject = new Number(10); var numberValue = 10; console.log(typeof numberObject); // Object console.log(typoef numberValue); // number console.log(numberObject instanceof Number); // true console.log(numberValue instanceof Number); // falseString類型 字符方法
charAt() charCodeAt()
charAt()方法以單字符字符串的形式返回給定位置的那個字符串。
charCodeAt()返回的是字符編碼。
var stringValue = "hello world"; console.log(stringValue.charAt(1)); // e console.log(stringValue.charCodeAt(1)); // 101字符串操作方法
concat()
concat()用于將一或多個字符串拼接起來。
var stringValue = "hello "; var result = stringValue.concat("world"); console.log(result); // hello world console.log(stringValue); // hello
slice(start, end)
end 表示字符串到哪里結(jié)束。
如果傳入的是負數(shù),slice()方法會將傳入的負值與字符串長度相加。
var str="Hello happy world!"; console.log(str.slice(6)); // happy world! console.log(str.slice(6,11));// happy console.log(str.slice(-3)); // ld! console.log(str.slice(3, -4)); //lo happy wo
substring(start, end)
如果傳入的是負數(shù), substring()會把所有字符參數(shù)都轉(zhuǎn)換為0
var str="Hello happy world!"; console.log(str.substring(6)); // happy world! console.log(str.substring(6,11));// happy console.log(str.substring(-3)); // Hello happy world! console.log(str.substring(3, -4)); //Hel
substr(start, length)
如果傳入的是負數(shù),substr()方法將負的第一個參數(shù)加上字符串的長度,而將負的第二個參數(shù)轉(zhuǎn)換為0
var str="Hello world!"; console.log(str.substr(3)); //lo world! console.log(str.substr(3, 7)); //lo worl console.log(str.substr(-3)); // ld! console.log(str.substr(3, -3)); // 空字符串字符串位置方法
indexOf() lastIndexOf()
var stringValue = "hello world"; console.log(stringValue.indexOf("o")); // 4 console.log(stringValue.lastIndexOf("o")); //7
這兩個方法都可以接收可選的第二個參數(shù),表示從字符串中的哪個位置開始搜索。
var stringValue = "hello world"; console.log(stringValue.indexOf("o", 6)); // 7 console.log(stringValue.lastIndexOf("o", 6)); //4字符串的模式匹配方法
match()
var text = "cat, bat, sat, fat"; var pattern = /.at/; var matches = text.match(pattern); console.log(matches.index); //0 console.log(matches[0]); // cat console.log(pattern.lastIndex); //0
search()
var text = "cat, bat, sat, fat"; var pos = text.search(/at/); console.log(pos); // 1
replace()
var text = "cat, bat, sat, fat"; var result = text.replace("at", "ond"); console.log(result); // cond, bat, sat, fat var result = text.replace(/at/g, "ond"); console.log(result); // cond, bond, sond, fond單體內(nèi)置對象 Global對象
URI編碼方法
Global對象的encodeURI()和encodeURIComponent()方法可以對URI(Uniform Resources Identifiers,通用資源標識符)進行編碼,以便發(fā)送給瀏覽器。
var url = "http://www.baidu.com/"; console.log(encodeURI(url)); console.log(encodeURIComponent(url));
encodeURI()和encodeURIComponent()方法對象的兩個方法分別是decodeURI()和decodeURIComponent()
Math對象random()方法
Math.random()方法返回介于0和1之間一個隨機數(shù),不包含0和1。對于某些站點來說,這個方法非常實用,因為可以利用它來隨機顯示一些名言和新聞事件。套用下面的公式,就可以利用Math.random()從某個整數(shù)范圍內(nèi)隨機選擇一個值。
值=Math.floor(Math.random()*可能值的總數(shù)+第一個可能的值)
例如:如果想選擇一個1到10之間的數(shù)值,可以像下面這邊編寫代碼:
var num = Math.floor(Math.random()*10+1); function selectFrom(lowerValue,upperValue){ var choice = upperValue - lowerValue + 1; return Math.floor(Math.random()*choice+lowerValue); } var num = selectFrom(2,10); console.log(num); var colors = ["red", "green", "blue", "yellow", "black", "purple", "brown"]; var color = colors[selectFrom(0, colors.length-1)]; console.log(color);
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/107006.html
摘要:三種使用構(gòu)造函數(shù)創(chuàng)建對象的方法和的作用都是在某個特殊對象的作用域中調(diào)用函數(shù)。這種方式還支持向構(gòu)造函數(shù)傳遞參數(shù)。叫法上把函數(shù)叫做構(gòu)造函數(shù),其他無區(qū)別適用情境可以在特殊的情況下用來為對象創(chuàng)建構(gòu)造函數(shù)。 一、工廠模式 工廠模式:使用字面量和object構(gòu)造函數(shù)會有很多重復(fù)代碼,在此基礎(chǔ)上改進showImg(https://segmentfault.com/img/bVbmKxb?w=456&...
摘要:繼承的是超類型中構(gòu)造函數(shù)中的屬性,如上繼承了屬性,但沒有繼承原型中的方法。上述造成的結(jié)果是子類型實例中有兩組超類型的構(gòu)造函數(shù)中定義的屬性,一組在子類型的實例中,一組在子類型實例的原型中。 ECMAScript只支持實現(xiàn)繼承,主要依靠原型鏈來實現(xiàn)。與實現(xiàn)繼承對應(yīng)的是接口繼承,由于script中函數(shù)沒有簽名,所以無法實現(xiàn)接口繼承。 一、原型鏈 基本思想:利用原型讓一個引用類型繼承另一個引用...
摘要:因此,所有在方法中定義的變量都是放在棧內(nèi)存中的當我們在程序中創(chuàng)建一個對象時,這個對象將被保存到運行時數(shù)據(jù)區(qū)中,以便反復(fù)利用因為對象的創(chuàng)建成本通常較大,這個運行時數(shù)據(jù)區(qū)就是堆內(nèi)存。 上一篇:《javascript高級程序設(shè)計》筆記:繼承近幾篇博客都會圍繞著圖中的知識點展開 showImg(https://segmentfault.com/img/bVY0C4?w=1330&h=618);...
摘要:作用域鏈中的下一個變量對象來自包含外部環(huán)境,而再下一個變量對象則來自下一個包含環(huán)境。這樣,一直延續(xù)到全局執(zhí)行環(huán)境全局執(zhí)行環(huán)境的變量對象始終都是作用域鏈中的最后一個對象標識符解析沿作用域鏈一級一級搜索標識符。 一、寫在前面 最近研究了創(chuàng)建Android虛擬機、vscode結(jié)合weex開發(fā)Android APP、Vmware裝MAC虛擬機的事,看的內(nèi)容不夠多,接下來加油 二、變量、作用域和...
摘要:解耦優(yōu)勢代碼復(fù)用,單元測試。常用比較誤區(qū)可同時判斷,可用來判斷對象屬性是否存在。使用作判斷無法進行充分的類型檢查。文件中應(yīng)用常量參考文檔高級程序設(shè)計作者以樂之名本文原創(chuàng),有不當?shù)牡胤綒g迎指出。 showImg(https://segmentfault.com/img/bVburXw?w=500&h=400); 編寫可維護性代碼 可維護的代碼遵循原則: 可理解性 (方便他人理解) 直觀...
摘要:上一篇你不知道的筆記寫在前面這是年第一篇博客,回顧去年年初列的學(xué)習(xí)清單,發(fā)現(xiàn)僅有部分完成了。當然,這并不影響年是向上的一年在新的城市穩(wěn)定連續(xù)堅持健身三個月早睡早起游戲時間大大縮減,學(xué)會生活。 上一篇:《你不知道的javascript》筆記_this 寫在前面 這是2019年第一篇博客,回顧去年年初列的學(xué)習(xí)清單,發(fā)現(xiàn)僅有部分完成了。當然,這并不影響2018年是向上的一年:在新的城市穩(wěn)定、...
閱讀 1832·2019-08-30 15:55
閱讀 1028·2019-08-26 11:57
閱讀 534·2019-08-26 11:29
閱讀 3376·2019-08-26 10:49
閱讀 1928·2019-08-23 18:40
閱讀 1835·2019-08-23 16:04
閱讀 3122·2019-08-23 11:01
閱讀 2293·2019-08-23 10:56