W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
Math
是 JavaScript 的原生對(duì)象,提供各種數(shù)學(xué)功能。該對(duì)象不是構(gòu)造函數(shù),不能生成實(shí)例,所有的屬性和方法都必須在Math
對(duì)象上調(diào)用。
Math
對(duì)象的靜態(tài)屬性,提供以下一些數(shù)學(xué)常數(shù)。
Math.E
:常數(shù)e
。Math.LN2
:2 的自然對(duì)數(shù)。Math.LN10
:10 的自然對(duì)數(shù)。Math.LOG2E
:以 2 為底的e
的對(duì)數(shù)。Math.LOG10E
:以 10 為底的e
的對(duì)數(shù)。Math.PI
:常數(shù)π
。Math.SQRT1_2
:0.5 的平方根。Math.SQRT2
:2 的平方根。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
對(duì)象提供以下一些靜態(tài)方法。
Math.abs()
:絕對(duì)值Math.ceil()
:向上取整Math.floor()
:向下取整Math.max()
:最大值Math.min()
:最小值Math.pow()
:冪運(yùn)算Math.sqrt()
:平方根Math.log()
:自然對(duì)數(shù)Math.exp()
:e
的指數(shù)Math.round()
:四舍五入Math.random()
:隨機(jī)數(shù)Math.abs
方法返回參數(shù)值的絕對(duì)值。
Math.abs(1) // 1
Math.abs(-1) // 1
Math.max
方法返回參數(shù)之中最大的那個(gè)值,Math.min
返回最小的那個(gè)值。如果參數(shù)為空, Math.min
返回Infinity
, Math.max
返回-Infinity
。
Math.max(2, -1, 5) // 5
Math.min(2, -1, 5) // -1
Math.min() // Infinity
Math.max() // -Infinity
Math.floor
方法返回小于或等于參數(shù)值的最大整數(shù)(地板值)。
Math.floor(3.2) // 3
Math.floor(-3.2) // -4
Math.ceil
方法返回大于或等于參數(shù)值的最小整數(shù)(天花板值)。
Math.ceil(3.2) // 4
Math.ceil(-3.2) // -3
這兩個(gè)方法可以結(jié)合起來,實(shí)現(xiàn)一個(gè)總是返回?cái)?shù)值的整數(shù)部分的函數(shù)。
function ToInteger(x) {
x = Number(x);
return x < 0 ? Math.ceil(x) : Math.floor(x);
}
ToInteger(3.2) // 3
ToInteger(3.5) // 3
ToInteger(3.8) // 3
ToInteger(-3.2) // -3
ToInteger(-3.5) // -3
ToInteger(-3.8) // -3
上面代碼中,不管正數(shù)或負(fù)數(shù),ToInteger
函數(shù)總是返回一個(gè)數(shù)值的整數(shù)部分。
Math.round
方法用于四舍五入。
Math.round(0.1) // 0
Math.round(0.5) // 1
Math.round(0.6) // 1
// 等同于
Math.floor(x + 0.5)
注意,它對(duì)負(fù)數(shù)的處理(主要是對(duì)0.5
的處理)。
Math.round(-1.1) // -1
Math.round(-1.5) // -1
Math.round(-1.6) // -2
Math.pow
方法返回以第一個(gè)參數(shù)為底數(shù)、第二個(gè)參數(shù)為指數(shù)的冪運(yùn)算值。
// 等同于 2 ** 2
Math.pow(2, 2) // 4
// 等同于 2 ** 3
Math.pow(2, 3) // 8
下面是計(jì)算圓面積的方法。
var radius = 20;
var area = Math.PI * Math.pow(radius, 2);
Math.sqrt
方法返回參數(shù)值的平方根。如果參數(shù)是一個(gè)負(fù)值,則返回NaN
。
Math.sqrt(4) // 2
Math.sqrt(-4) // NaN
Math.log
方法返回以e
為底的自然對(duì)數(shù)值。
Math.log(Math.E) // 1
Math.log(10) // 2.302585092994046
如果要計(jì)算以10為底的對(duì)數(shù),可以先用Math.log
求出自然對(duì)數(shù),然后除以Math.LN10
;求以2為底的對(duì)數(shù),可以除以Math.LN2
。
Math.log(100)/Math.LN10 // 2
Math.log(8)/Math.LN2 // 3
Math.exp
方法返回常數(shù)e
的參數(shù)次方。
Math.exp(1) // 2.718281828459045
Math.exp(3) // 20.085536923187668
Math.random()
返回0到1之間的一個(gè)偽隨機(jī)數(shù),可能等于0,但是一定小于1。
Math.random() // 0.7151307314634323
任意范圍的隨機(jī)數(shù)生成函數(shù)如下。
function getRandomArbitrary(min, max) {
return Math.random() * (max - min) + min;
}
getRandomArbitrary(1.5, 6.5)
// 2.4942810038223864
任意范圍的隨機(jī)整數(shù)生成函數(shù)如下。
function getRandomInt(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
getRandomInt(1, 6) // 5
返回隨機(jī)字符的例子如下。
function random_str(length) {
var ALPHABET = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
ALPHABET += 'abcdefghijklmnopqrstuvwxyz';
ALPHABET += '0123456789-_';
var str = '';
for (var i = 0; i < length; ++i) {
var rand = Math.floor(Math.random() * ALPHABET.length);
str += ALPHABET.substring(rand, rand + 1);
}
return str;
}
random_str(6) // "NdQKOr"
上面代碼中,random_str
函數(shù)接受一個(gè)整數(shù)作為參數(shù),返回變量ALPHABET
內(nèi)的隨機(jī)字符所組成的指定長度的字符串。
Math
對(duì)象還提供一系列三角函數(shù)方法。
Math.sin()
:返回參數(shù)的正弦(參數(shù)為弧度值)Math.cos()
:返回參數(shù)的余弦(參數(shù)為弧度值)Math.tan()
:返回參數(shù)的正切(參數(shù)為弧度值)Math.asin()
:返回參數(shù)的反正弦(返回值為弧度值)Math.acos()
:返回參數(shù)的反余弦(返回值為弧度值)Math.atan()
:返回參數(shù)的反正切(返回值為弧度值)
Math.sin(0) // 0
Math.cos(0) // 1
Math.tan(0) // 0
Math.sin(Math.PI / 2) // 1
Math.asin(1) // 1.5707963267948966
Math.acos(1) // 0
Math.atan(1) // 0.7853981633974483
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: