JavaScript/TypeScript中==和===的區(qū)別詳解
在JS/TS項(xiàng)目里,除了能看到==操作符來判斷兩個(gè)變量是否相等外,我們還會看到===操作符,這兩者有什么區(qū)別嗎?
先上結(jié)論,
- 對于String, number這些基礎(chǔ)類型,==操作符會先把兩邊的變量進(jìn)行類型強(qiáng)制轉(zhuǎn)換成相同的類型再比較是否相等;===操作符則不會進(jìn)行類型轉(zhuǎn)換,而是直接進(jìn)行比較。
- 對于array, object這些高級類型,==和 ===是沒有區(qū)別的,因?yàn)樗鼈儽容^的是 “指針地址” 。
- 對于基礎(chǔ)類型和高級類型,== 和 ===是有區(qū)別的;==操作符會先把高級類型轉(zhuǎn)換為基礎(chǔ)類型之后,進(jìn)行值的比較;===操作符則不會進(jìn)行轉(zhuǎn)換,類型不同,直接返回false
也就是說,`==`操作符只要求比較兩個(gè)變量的值是否相等,`===`操作符則是要求兩個(gè)變量的值和類型都要相同;類似地,`!=`操作符會去做類型強(qiáng)制轉(zhuǎn)換,`!==`操作符則不會轉(zhuǎn)換類型。
我們寫個(gè)基礎(chǔ)類型變量的代碼示例一下:
66 == '66'; // 返回true 66 === '66' // 返回false
==操作符會把第一行里的字符串轉(zhuǎn)換成數(shù)字,與66再進(jìn)行比較,值相等,于是返回true;===操作符則不會做類型轉(zhuǎn)換,因?yàn)樽筮厰?shù)字,右邊字符串,兩者類型不同,就會返回false。
注意對于特殊值NaN(Not a Number),表示非數(shù)字,NaN和任何數(shù)(包括它自己)做相等比較,都會返回false,所以判斷NaN最好用isNaN()函數(shù);
而對于undefined和null,兩者的值相比較,會返回true。
代碼示例如下:
NaN == 6; // 返回false NaN === NaN; // 返回false null == undefined; // 返回true null === undefined; // 返回false
最后, 由于==和!=操作符帶來的類型隱式轉(zhuǎn)換規(guī)則非常繁瑣,還有為了避免數(shù)據(jù)類型混淆導(dǎo)致出現(xiàn)bug,還是推薦使用===操作符和!==操作符。
js在比較的時(shí)候如果是 == 會先做類型轉(zhuǎn)換,再判斷值得大小,如果是===類型和值必須都相等。


總結(jié)
到此這篇關(guān)于 JavaScript/TypeScript中==和===區(qū)別的文章就介紹到這了,更多相關(guān) js/ts中==和===的區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javascript實(shí)現(xiàn)獲取指定精度的上傳文件的大小簡單實(shí)例
下面小編就為大家?guī)硪黄猨avascript實(shí)現(xiàn)獲取指定精度的上傳文件的大小簡單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10
Javascript和Java獲取各種form表單信息的簡單實(shí)例
本篇文章主要是對Javascript和Java獲取各種form表單信息的簡單實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02
JS實(shí)現(xiàn)很實(shí)用的對聯(lián)廣告代碼(可自適應(yīng)高度)
這篇文章主要介紹了JS實(shí)現(xiàn)很實(shí)用的對聯(lián)廣告代碼,可實(shí)現(xiàn)固定相對位置懸浮展示及跟隨屏幕上下滑動(dòng)等功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
ES6模塊化的import和export用法方法總結(jié)
這篇文章主要介紹了ES6模塊化的import和export用法方法總結(jié),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08
Javascript 對象(object)合并操作實(shí)例分析
這篇文章主要介紹了Javascript 對象(object)合并操作,結(jié)合實(shí)例形式分析了javascript基于jQuery的extend方法、對象屬性、遍歷賦值等操作實(shí)現(xiàn)對象合并相關(guān)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2019-07-07
js使用for循環(huán)及if語句判斷多個(gè)一樣的name
這篇文章主要介紹了js使用for循環(huán)機(jī)if語句判斷多個(gè)一樣的name,此法比較實(shí)用,需要的朋友可以參考下2014-09-09

