摘要:二進制和八進制表示法提供了二進制和八進制數值的新的寫法,分別用前綴或和或表示。用來檢查是否為有窮以及是否為這兩個新方法只對數值有效,非數值一律返回。引入了和這兩個常量,用來表示這個范圍的上下限。因為有精度限制,超過的次方的值無法精確表示。
1 二進制和八進制表示法
ES6提供了二進制和八進制數值的新的寫法,分別用前綴0b(或0B)和0o(或0O)表示。
console.log(0b1001110010); //626 console.log(0o626); //4062 Number.isFinite(),Number.isNaN()
ES5:
isFinite(),isNaN()
ES6:
Number.isFinite(),Number.isNaN()
用來檢查是否為有窮以及是否為NaN;
console.log(Number.isFinite(Infinity)); //false console.log(Number.isNaN(NaN)); //true
這兩個新方法只對數值有效,非數值一律返回false。
3 Number.parseInt(),Number.parseFloat()ES5:
parseInt(),parseFloat()
ES6:
Number.parseInt(),Number.parseFloat()
新方法移植到Number對象上,行為與ES5一致
console.log(Number.parseInt("123.21")); //123 console.log(Number.parseFloat("321.321hr")); //321.3214 Number.isInterger()
因為浮點數和整數是同樣的儲存方法,所以.0將被理解為整數
5 Number.EPSILON極小的常量
console.log(Number.EPSILON); //2.220446049250313e-16 console.log(Number.EPSILON.toFixed(16)); //0.0000000000000002 let result = 0.1 + 0.2; console.log((result - 0.3) < Number.EPSILON.toFixed(16)); //True6 安全整數和Number.isSafeInteger()
JavaScript能夠準確表示的整數范圍在-2^53到2^53之間(不含兩個端點),超過這個范圍,無法精確表示這個值。
ES6引入了Number.MAX_SAFE_INTEGER和Number.MIN_SAFE_INTEGER這兩個常量,用來表示這個范圍的上下限。
需要注意的是不要只驗證運算結果,同時必須驗證參與運算的每個值
console.log(Number.MAX_SAFE_INTEGER); //9007199254740991 console.log(Number.isSafeInteger(Number.MAX_SAFE_INTEGER + 1)); //false7 Math 對象的擴展
Math.trunc()
Math.trunc方法用于去除一個數的小數部分,返回整數部分。
Math.trunc(4.1) // 4
Math.sign()
Math.sign方法用來判斷一個數到底是正數、負數、還是零。
console.log(Math.sign(321)); //1 console.log(Math.sign(-321)); //-1 console.log(Math.sign(-0)); //-0 console.log(Math.sign(0)); //0
Math.cbrt()
Math.cbrt方法用于計算一個數的立方根。
console.log(Math.cbrt(8)); //2
Math.clz32()
JavaScript的整數使用32位二進制形式表示,Math.clz32方法返回一個數的32位無符號整數形式有多少個前導0。
Math.clz32(0b01000000000000000000000000000000) // 1 Math.clz32(0b00100000000000000000000000000000) // 2
需要注意的是對于小數,改方法只考慮整數部分
Math.imul()
Math.imul方法返回兩個數以32位帶符號整數形式相乘的結果,返回的也是一個32位的帶符號整數。
因為JavaScript有精度限制,超過2的53次方的值無法精確表示。這就是說,對于那些很大的數的乘法,低位數值往往都是不精確的,Math.imul方法可以返回正確的低位數值。
Math.fround()
返回一個數的單精度浮點數形式。
Math.fround(1); // 1 Math.fround(1.337); // 1.3370000123977661 Math.fround(1.5); // 1.5 Math.fround(NaN); // NaN
Math.hypot()
返回所有參數的平方和的平方根。
Math.hypot(3, 4, 5); // 7.0710678118654755 Math.hypot(); // 0 Math.hypot(NaN); // NaN Math.hypot(3, 4, "foo"); // NaN
對數方法
Math.expm1()
返回Math.exp(x) - 1
Math.log1p()
返回Math.log(1 + x)
Math.log10()
以10為底的x的對數
Math.log2()
以2為底的x的對數
三角函數方法
Math.sinh(x) 返回x的雙曲正弦(hyperbolic sine)
Math.cosh(x) 返回x的雙曲余弦(hyperbolic cosine)
Math.tanh(x) 返回x的雙曲正切(hyperbolic tangent)
Math.asinh(x) 返回x的反雙曲正弦(inverse hyperbolic sine)
Math.acosh(x) 返回x的反雙曲余弦(inverse hyperbolic cosine)
Math.atanh(x) 返回x的反雙曲正切(inverse hyperbolic tangent)
8 指數運算符**ES7 新增的指數運算符**
2 ** 2 //4 2 ** 3 //8
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/79108.html
摘要:基本用法所聲明的變量,只在命令所在的代碼塊內有效。在循環中適合使用不存在變量提升不像那樣會發生變量提升現象暫時性死區只要塊級作用域內存在命令,它所聲明的變量就綁定這個區域,不再受外部的影響。塊級作用域實際上為新增了塊級作用域。 1 let 基本用法 所聲明的變量,只在let命令所在的代碼塊內有效。 { let b = 100; console.log(b); //100...
摘要:第二個參數指定修飾符,如果存在則使用指定的修飾符。屬性表示是否設置了修飾符屬性的屬性返回正則表達式的正文的屬性返回正則表達式的修飾符字符串必須轉義,才能作為正則模式。 1 RegExp構造函數 ES6 允許RegExp構造函數接受正則表達式作為參數。第二個參數指定修飾符,如果存在則使用指定的修飾符。 var regexp = new RegExp(/xyz/i, ig); consol...
摘要:數組的解構賦值允許按照一定模式,從數組和對象中提取值,對變量進行賦值,這被稱為解構。如果變量名與屬性名不一致,必須寫成下面這樣。 1 數組的解構賦值 ES6允許按照一定模式,從數組和對象中提取值,對變量進行賦值,這被稱為解構(Destructuring)。 基本用法 { var [a,[b,c],d,,...f] = [1,[2,3],4,5,6,7]; console...
摘要:吉字符串的遍歷器接口為字符串添加了遍歷器接口,使得字符串可以被循環遍歷。提供字符串實例的方法,用來將字符的不同表示方法統一為同樣的形式,這稱為正規化。返回布爾值,表示參數字符串是否在源字符串的頭部。 1 字符串的Unicode表示法 ES6 只要將碼點放入大括號,就能正確解讀該字符; var x = u20bb7; document.write(x); //?7 var x = u{2...
摘要:屬性的簡潔表示法允許直接寫入變量和函數作為對象的屬性和方法。,中有返回一個數組,成員是參數對象自身的不含繼承的所有可遍歷屬性的鍵名。對象的擴展運算符目前,有一個提案,將解構賦值擴展運算符引入對象。 1 屬性的簡潔表示法 ES6允許直接寫入變量和函數作為對象的屬性和方法。 寫入屬性 var name = value; var obj = { name }; console.log...
閱讀 3537·2021-10-09 09:41
閱讀 2742·2021-10-08 10:18
閱讀 2178·2021-09-10 10:51
閱讀 2677·2021-09-10 10:50
閱讀 773·2021-09-09 09:33
閱讀 3380·2021-09-06 15:14
閱讀 3014·2019-08-30 11:06
閱讀 3244·2019-08-29 14:04