国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

javascript數據類型中的一些小知識點(推薦)

2024-05-06 16:50:06
字體:
來源:轉載
供稿:網友

1. undefined 和 null

undefined是一個變量而不是一個關鍵字,所以可以被重新賦值。為了避免歧義,一般推薦用void 0 來獲取undefined;

null是一個關鍵字,所以可以放心地使用null。

Undefined 跟 null 有一定的表意差別,null 表示的是:“定義了但是為空”。所以,在實際編程時,我們一般不會把變量賦值為 undefined,這樣可以保證所有值為 undefined 的變量,都是從未賦值的自然狀態。 

function test(){  var undefined = 123;  console.log(undefined) }test() ==> 123

2. +0 和 -0

JavaScript 中有 +0 和 -0,在加法類運算中它們沒有區別,要區別他們的話,需要使用1/x 

3/0 ==> Infinity3/-0 ==> -Infinity

3. 0.1 + 0.2 = 0.3?

在JS中,0.1+0.2是不等于0.3的,因為0.1在計算機中用二進制表示的話,會產生無限循環位數。類似于十進制中,三分之一就是無限循環小數。

所以對這些循環小數進行數學運算時,并將二進制數據再轉換成十進制時,也還是無線循環小數,對末尾進行截取后,得到的值就是0.30000000000000004

正確的比較方法是使用JS提供的最小精度值,檢查等式左右兩邊差的絕對值是否小于最小精度

Math.abs(0.1 + 0.2 - 0.3) <= Number.EPSILONtrue

4. 666 和 new Number(666)的區別

666是一個number類型的數字,而Number(666)是一個對象類型的數據。

‘HELLO'.charAt(1) ==》 'E'

上門代碼中,點(.)運算符提供了裝箱操作,會根據一個基礎類型構造一個臨時對象,所以能在基礎類型上調用對應對象的方法

5. parseInt 和 parseFloat

parseInt(string, radix)

javascript,數據類型

parseInt(15,6)11 ==> 1*6+5parseInt(0x15) 21 ==> 16*1+5

parseFloat 則直接把原字符串作為十進制來解析,它不會引入任何的其他進制

6. 裝箱轉換

每一種基本類型 Number、String、Boolean、Symbol 在對象中都有對應的類,所謂裝箱轉換,正是把基本類型轉換為對應的對象。

Symbol 比較特殊,不能直接用 new Symbol獲得對應的對象, 可以用Object(Symbol('hello')) 來獲得。

 var symbolObject = Object(Symbol("a"));  console.log(typeof symbolObject); //object  console.log(symbolObject instanceof Symbol); //true  console.log(symbolObject.constructor == Symbol); //true

7. 拆箱轉換

把對象轉換成number或string時,會默認進行拆箱轉換,即會調用對象內置的toString或者valueOf方法將對象轉換成基本類型

javascript,數據類型

這兒定義了一個obj對象,重寫了它的valueOf和toString方法進行測試,可以看到,當Number(obj)時,valueOf優先于String執行,但是當這2個方法都沒有返回基本類型的數據時,就會產生錯誤。

 javascript,數據類型

當valueOf方法返回基本類型的數據時,成功將obj轉換成了數字,而且toSring方法沒有執行。

 javascript,數據類型

當valueOf返回非基本類型時,toString方法才會被調用。只有當Object到 String 的拆箱轉換才會優先調用 toString方法。

 注:ES6允許對象通過顯式指定 toPrimitive Symbol 來覆蓋原有的行為。

var o = {    valueOf : () => {console.log("valueOf"); return {}},    toString : () => {console.log("toString"); return {}}  }  o[Symbol.toPrimitive] = () => {console.log("toPrimitive"); return "hello"}  console.log(o + "")  // toPrimitive  // hello

以上所述是小編給大家介紹的javascript數據類型中的一些小知識點解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VeVb武林網網站的支持!


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 凌源市| 新巴尔虎右旗| 天水市| 清水河县| 新丰县| 海阳市| 郑州市| 广安市| 江西省| 唐海县| 蒙山县| 新安县| 阿克陶县| 永丰县| 报价| 南投市| 托里县| 隆安县| 年辖:市辖区| 霞浦县| 永宁县| 平罗县| 石林| 龙游县| 遂宁市| 新民市| 磴口县| 濮阳县| 张家界市| 龙胜| 吉木萨尔县| 晋州市| 子长县| 昭苏县| 青神县| 同仁县| 定州市| 长垣县| 开平市| 大田县| 双桥区|