JavaScript之math() date() array()歸納


Math

Math對象時JavaScript的內(nèi)置對象,提供一系列數(shù)學(xué)常數(shù)和數(shù)學(xué)方法。Math對象只提供了靜態(tài)的屬性和方法。

Math屬性(只讀的數(shù)學(xué)常數(shù))

Math.E // 2.718281828459045
Math.LN2 // 0.6931471805599453
Math.LN10 // 2.302585092994046
Math.LOG2E // 1.4426950408889634
Math.LOG10E // 0.4342944819032518
Math.PI // 3.141592653589793
Math.SQRT1_2 // 0.7071067811865476
Math.SQRT2 // 1.4142135623730951

Math方法

1. round
round方法用于四舍五入

Math.round(0.1) // 0
Math.round(0.5) // 1
注意:它對于負(fù)值的運算結(jié)果和正值略有不同,主要體現(xiàn)在對 .5的處理。

2.abs,max,min
abs方法返回參數(shù)值的絕對值

Math.abs(1) //1
Math.abs(-1) //1

max方法返回最大的參數(shù),min方法返回最小的參數(shù)

Math.max(2,-1,5) //5
Math.min(2,-1,5) //-1

3.floor,ceil
floor方法返回小于參數(shù)值的最大整數(shù)

Math.floor(3.2) //3
Math.floor(-3.2) //-4

ceil方法返回大于參數(shù)值的最小整數(shù)

Math.celi(3.2) //4
Math.celi(-3.2) //-3

4.pow,sqrt,log,exp
pow方法返回第一個參數(shù)為底數(shù),第二個參數(shù)為冪的值
sqrt方法返回參數(shù)值的平方根(如果參數(shù)是負(fù)數(shù)就返回NaN)
log方法返回以e為底的自然數(shù)對數(shù)
exp方法返回常數(shù)e的參數(shù)次方

5.random
random方法返回0到1之間的一個偽隨機數(shù),區(qū)間 [0,1)

// 返回給定范圍內(nèi)的隨機數(shù)
function getRandomArbitrary(min, max) {
return Math.random() * (max - min) + min;
}
// 返回給定范圍內(nèi)的隨機整數(shù)
function getRandomInt(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}


Date

Date對象是JavaScript提供的日期和時間的操作接口

Date方法

1.Date.now()
now方法返回當(dāng)前距離 1970年1月1日00:00:00的毫秒數(shù)

2.Date.parse()
parse方法用來解析日期字符串,返回距離1970年1月1日 00:00:00的毫秒數(shù)
日期字符串的格式應(yīng)該完全或者部分符合YYYY-MM-DDTHH:mm:ss.sssZ格式,Z表示時區(qū),是可選的
如果解析失敗,返回NaN

Date.parse("January 26, 2011 13:51:50")
Date.parse("Mon, 25 Dec 1995 13:30:00 GMT")

3.Date.UTC()
默認(rèn)情況下,Date對象返回的都是當(dāng)前時區(qū)的時間
Date.UTC方法可以返回UTC時間。該方法接受年、月、日等變量作為參數(shù),返回當(dāng)前距離1970年1月1日 00:00:00 UTC的毫秒數(shù)

4.Date()
Date函數(shù)可以直接調(diào)用,返回一個當(dāng)前日期和時間的字符串,這時候是否有參數(shù)結(jié)果一樣

5.get

Date.prototype.getTime():返回實例對象距離1970年1月1日00:00:00對應(yīng)的毫秒數(shù),等同于valueOf方法
Date.prototype.getDate():返回實例對象對應(yīng)每個月的幾號(從1開始)
Date.prototype.getDay():返回星期,星期日為0,星期一為1,以此類推
Date.prototype.getFullYear():返回四位的年份

Date.prototype.getMonth():返回月份(0表示1月,11表示12月)
Date.prototype.getHours():返回小時(0-23)
Date.prototype.getMilliseconds():返回毫秒(0-999)
Date.prototype.getMinutes():返回分鐘(0-59)
Date.prototype.getSeconds():返回秒(0-59)
Date.prototype.getTimezoneOffset():返回當(dāng)前時間與UTC的時區(qū)差異,以分鐘表示,返回結(jié)果考慮到了夏令時因素

6.set

Date.prototype.setDate(date):設(shè)置實例對象對應(yīng)的每個月的幾號(1-31),返回改變后毫秒時間戳
Date.prototype.setFullYear(year [, month, date]):設(shè)置四位年份
Date.prototype.setHours(hour [, min, sec, ms]):設(shè)置小時(0-23)
Date.prototype.setMilliseconds():設(shè)置毫秒(0-999)
Date.prototype.setMinutes(min [, sec, ms]):設(shè)置分鐘(0-59)
Date.prototype.setMonth(month [, date]):設(shè)置月份(0-11)

Date.prototype.setSeconds(sec [, ms]):設(shè)置秒(0-59)
Date.prototype.setTime(milliseconds):設(shè)置毫秒時間戳


Array

在程序語言中數(shù)組的重要性不言而喻,JavaScript中數(shù)組也是最常使用的對象之一,數(shù)組是值的有序集合,由于弱類型的原因,JavaScript中數(shù)組十分靈活、強大,不像是Java等強類型高級語言數(shù)組只能存放同一類型或其子類型元素,JavaScript在同一個數(shù)組中可以存放多種類型的元素,而且長度也是可以動態(tài)調(diào)整的,可以隨著數(shù)據(jù)增加或減少自動對數(shù)組長度做更改。

創(chuàng)建數(shù)組

構(gòu)造函數(shù)創(chuàng)建數(shù)組

1.無參構(gòu)造函數(shù),創(chuàng)建一空數(shù)組
var a1 = new Array();
2.一個數(shù)字參數(shù)構(gòu)造函數(shù),指定數(shù)組長度(由于數(shù)組長度可以動態(tài)調(diào)整,作用并不大),創(chuàng)建指定長度的數(shù)組
var a2 = new Array(5);
3.帶有初始化數(shù)據(jù)的構(gòu)造函數(shù),創(chuàng)建數(shù)組并初始化參數(shù)數(shù)據(jù)
var a3 = new Array(4, 'hello', new Date());

字面量創(chuàng)建數(shù)組

1.使用方括號,創(chuàng)建空數(shù)組,等同于調(diào)用無參構(gòu)造函數(shù)
var a4 = [];
2.使用中括號,并傳入初始化數(shù)據(jù),等同于調(diào)用帶有初始化數(shù)據(jù)的構(gòu)造函數(shù)
var a5 = [10];

注意點
1.在使用構(gòu)造函數(shù)創(chuàng)建數(shù)組時如果傳入一個數(shù)字參數(shù),則會創(chuàng)建一個長度為參數(shù)的數(shù)組,如果傳入多個,則創(chuàng)建一個數(shù)組,參數(shù)作為初始化數(shù)據(jù)加到數(shù)組中
var a1 = new Array(5);
console.log(a1.length);//5
console.log(a1); //[] ,數(shù)組是空的
var a2 = new Array(5,6);
console.log(a2.length);//2
console.log(a2); //[5,6]
但是使用字面量方式,無論傳入幾個參數(shù),都會把參數(shù)當(dāng)作初始化內(nèi)容
var a1 = [5];
console.log(a1.length);//1
console.log(a1); //[5]
var a2 = [5,6];
console.log(a2.length);//2
console.log(a2); //[5,6]

2.使用帶初始化參數(shù)的方式創(chuàng)建數(shù)組的時候,最好最后不要帶多余的”,”,在不同的瀏覽器下對此處理方式不一樣
var a1 = [1,2,3,];
console.log(a1.length);
console.log(a1);
這段腳本在現(xiàn)代瀏覽器上運行結(jié)果和我們設(shè)想一樣,長度是3,但是在低版本IE下確實長度為4的數(shù)組,最后一條數(shù)據(jù)是undefined

Array方法

1.pop,push(棧方法)
pop和push能夠讓我們使用堆棧那樣先入后出使用數(shù)組

var a = new Array(1,2,3);
a.push(4);
console.log(a);//[1, 2, 3, 4]
console.log(a.length);//4
console.log(a.pop());//4
console.log(a); //[1, 2, 3]
console.log(a.length);//3

2.shift,unshift(隊列方法)
既然棧方法都實現(xiàn)了,先入先出的隊列怎么能少,shift方法可以刪除數(shù)組index最小元素,并使后面元素index都減一,length也減一,這樣使用shift/push就可以模擬隊列了,當(dāng)然與shift方法對應(yīng)的有一個unshift方法,用于向數(shù)組頭部添加一個元素

var a=new Array(1,2,3);
a.unshift(4);
console.log(a);//[4, 1, 2, 3]
console.log(a.length);//4
console.log(a.shift());//4
console.log(a); //[1, 2, 3]
console.log(a.length);//3

3.終極皮皮蝦神級方法--splice

JavaScript提供了一個splice方法用于一次性解決數(shù)組添加、刪除(這兩種方法一結(jié)合就可以達(dá)到替換效果),方法有三個參數(shù)

1.開始索引

2.刪除元素的位移

3.插入的新元素,當(dāng)然也可以寫多個

splice方法返回一個由刪除元素組成的新數(shù)組,沒有刪除則返回空數(shù)組

常用操作

1.join(char)
這個方法在C#等語言中也有,作用是把數(shù)組元素(對象調(diào)用其toString()方法)使用參數(shù)作為連接符連接成一字符串,不會修改原數(shù)組內(nèi)容

var a = new Array(1,2,3,4,5);
console.log(a.join(',')); //1,2,3,4,5
console.log(a.join(' ')); //1 2 3 4 5

**2.slice(start,end)
不要和splice方法混淆,slice方法用于返回數(shù)組中一個片段或子數(shù)組,如果只寫一個參數(shù)返回參數(shù)到數(shù)組結(jié)束部分,如果參數(shù)出現(xiàn)負(fù)數(shù),則從數(shù)組尾部計數(shù)(-3意思是數(shù)組倒第三個,一般人不會這么干,但是在不知道數(shù)組長度,想舍棄后n個的時候有些用,不過數(shù)組長度很好知道。。。。,好糾結(jié)的用法),如果start大于end返回空數(shù)組,值得注意的一點是slice不會改變原數(shù)組,而是返回一個新的數(shù)組

var a = new Array(1,2,3,4,5);
console.log(a); //[1, 2, 3, 4, 5]
console.log(a.slice(1,2));//2
console.log(a.slice(1,-1));//[2, 3, 4]
console.log(a.slice(3,2));//[]
console.log(a); //[1, 2, 3, 4, 5]

3.concat(array)
看起來像是剪切,但這個真不是形聲字,concat方法用于拼接數(shù)組,a.concat(b)返回一個a和b共同組成的新數(shù)組,同樣不會修改任何一個原始數(shù)組,也不會遞歸連接數(shù)組內(nèi)部數(shù)組

var a = new Array(1,2,3,4,5);
var b = new Array(6,7,8,9);
console.log(a.concat(b));//[1, 2, 3, 4, 5, 6, 7, 8, 9]
console.log(a); //[1, 2, 3, 4, 5]
console.log(b); //[6, 7, 8, 9]

**4.reverse()
方法用于將數(shù)組逆序,與之前不同的是它會修改原數(shù)組

var a = new Array(1,2,3,4,5);
a.reverse();
console.log(a); //[5, 4, 3, 2, 1]

5.sort()
sort方法用于對數(shù)組進行排序,當(dāng)沒有參數(shù)的時候會按字母表升序排序,如果含有undefined會被排到最后面,對象元素則會調(diào)用其toString方法,如果想按照自己定義方式排序,可以傳一個排序方法進去,很典型的策略模式,同樣sort會改變原數(shù)組。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,702評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,143評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,553評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,620評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 71,416評論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,940評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,024評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,170評論 0 287
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,709評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 40,597評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,784評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,291評論 5 357
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,029評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,407評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,663評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,403評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 47,746評論 2 370

推薦閱讀更多精彩內(nèi)容