摘要:的使用這是一個運算符,不是方法檢測數據類型,返回的結果是一個字符串類型。在檢查相等性時,不能把和轉換成其他值。
1 typeof的使用;這是一個運算符,不是方法
1.1檢測數據類型,返回的結果是一個字符串類型。有六種可能:number boolean string object function undefined
注意typeof(null) 返回的是 : object
1.2 typeof 可以用于被聲明 或者未被聲明 的變量;但是未被聲明 的變量不能用其他運算符運算,之外的其他運算符的話,會引起錯誤,因為其他運算符只能用于已聲明的變量上。
1.3 對于基本數據類型(Number Boolean String null undefined) 以及引用類型 object的typeof值
1.3.1類 : Object Function Array String Boolean Number Date ;這些未初始化為實例的類的typeof類型為function
function test (){ } console.log(Object);//function Object() { [native code] } console.log(typeof Object);//function console.log(Array);//function Array() { [native code] } console.log(typeof Array);//function console.log(Function);//function Function() { [native code] } console.log(typeof Function);//function console.log(String);//function String() { [native code] } console.log(typeof String);//function console.log(test);//function test(){ } console.log(typeof test);//function
1.3.2 對象的創建方式是用關鍵字 new 后面跟上實例化的類的名字,當將一個函數通過new實例化之后,那么就創建了一個對象
function test (){ } var obj = new test(); console.log(obj.constructor);//function test(){} console.log(obj);//test{} console.log(typeof obj);//Object var obj1 = new Array(); console.log(obj1.constructor);//function Array() { [native code] } console.log(obj1);//[] console.log(typeof obj1);//Object var obj2 = new Function(); console.log(obj2.constructor);//function Function() { [native code] } console.log(obj2);//function anonymous() {} console.log(typeof obj2);//function var obj3 = new String(); console.log(obj3.constructor);//function String() { [native code] } console.log(obj3);//String {length: 0, [[PrimitiveValue]]: ""} console.log(typeof obj3);//object var obj4 = new Object(); console.log(obj4.constructor);//function Object() { [native code] } console.log(obj4);//Object {} console.log(typeof obj4);//object
1.3.3 基本數據類型的typeof的值
1.3.5 通過上面分析我們發現typeof可以判斷基本數據類型,但是對于復雜數據類型,返回都是object,那么如何檢測object的"類"呢?也就是說,如何檢測一個對象是由哪個構造函數創建的呢?
這個時候就要用到 instanceof 了;語法: obj instanceof Type ,會沿著對象的原型鏈一層層的找,如果找到由Type類型的則返回true,否則返回false;
function test (){ } var obj = new test(); console.log(obj.constructor);//function test(){} console.log(obj);//test{} console.log(typeof obj);//Object console.log(obj instanceof test);//true 表示obj對象時test這個構造函數產生的
2 null undefined
2.1 null是一個表示"無"的對象,轉化為數值的時候值為0;典型的用法是:
用來初始化一個變量,該變量將來可能會被賦值成一個對象
用來和一個已經初始化的對象進行比較,這個變量可以是一個對象,也可以不是一個對象
當函數的參數期望是對象時,被用作參數傳入
當函數返回值期望是對象時,被當做返回值輸出
刪除事件綁定,事件本身是一個 null ,是一個空的對象,可以添加
作為對象原型鏈的終點
2.2 undefined 是一個表示"無"的原始值,轉化為數值的時候值為0 ;典型用法是:
變量被聲明了,但是沒有賦值,那么該變量的值就是undefined
調用一個函數的時候,如果應該提供的參數沒有提供,那么該參數默認是undefined
如果一個對象的屬性沒有賦值,那么該屬性值為undefined
函數沒有返回值的時候,默認返回undefined;
2.3 如何區分二者?
== 運算符只比較值,不進行類型的比較,比較之前會進行隱式轉化,null==undefined 返回true.
=== 區分兩者,不僅僅比較內容,還比較數據類型 null===undefined false
如何判斷一個變量是null還是undefined?
如何確定一個變量是undefined;
var exp = undefined ;//var exp ;如果不進行賦值的話,結果也是undefined
//這種方法是錯誤的,因為null==undefined 返回true;
if(exp == undefined){
console.log("exp變量是undefined");
}
//這種方法才是正確的,注意undefined加"" ,因為typeof返回的值是一個字符串類型的
if(typeof(exp) == "undefined"){
console.log("exp變量是undefined");
}
以下附上== 運算符的W3C解釋,方便讀者回憶基礎
執行類型轉化遵循的規則: 如果一個運算數是 Boolean 值,在檢查相等性之前,把它轉換成數字值。false 轉換成 0,true 為 1。 如果一個運算數是字符串,另一個是數字,在檢查相等性之前,要嘗試把字符串轉換成數字。 如果一個運算數是對象,另一個是字符串,在檢查相等性之前,要嘗試把對象轉換成字符串。 如果一個運算數是對象,另一個是數字,在檢查相等性之前,要嘗試把對象轉換成數字。 還遵循以下轉化規則: 值 null 和 undefined 相等。 在檢查相等性時,不能把 null 和 undefined 轉換成其他值。 如果某個運算數是 NaN,等號將返回 false,非等號將返回 true。 如果兩個運算數都是對象,那么比較的是它們的引用值。如果兩個運算數指向同一對象,那么等號返回 true,否則兩個運算數不等。
我覺得可以進行再簡化,來進行解釋這個比較過程:
如果其中一個是布爾類型則先將布爾類型轉化 為0 或者 1 ; 如果一個是對象,和字符串、 數字 或者 布爾類型 進行比較的時候則將對象轉化為原始值,對象通過toString valueOf 查看原始值,然后在與字符串 數字 布爾類型進行比較
如何確定一個變量是null
var exp = null;
//以下兩種是不正確的
if(!exp){ //0 或者undefined同樣可以進入if語句
console.log("該變量是null");
}
if(exp == null ){ //undefined == null 返回true
console.log("該變量是null")
}
//下面這種才是正確判斷null 類型的
if(typeof(exp) == "object" && exp == null){ //同時進行類型和內容的判斷
console.log("該變量是null");
}
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/81783.html
摘要:本文將講解我目前所知道的判斷數據類型的方法。數據類型一共有種除了之外的種屬于原始數據類型。等價于問題四的返回值是什么答案。 本文將講解我目前所知道的判斷JavaScript數據類型的方法。JavaScript數據類型一共有7種: Undefined Null Boolean String Symbol Number Object 除了Object之外的6種屬于原始數據類型。有時,我...
摘要:和這三種基本的數據類型,都有對應的引用包裝類型和。應用于引用類型的判斷,所以對于這三類基本類型沒有什么意義。 JS 中的類型判斷 js中的數據類型 基本數據類型 undefined、number、string、boolean 引用數據類型 null、Object、Number、String、Boolean、Function、Array、Date、RegExp、Error、Argumen...
摘要:第十六天筆記基礎語法區分大小寫是一種區分大小寫的語言的關鍵字變量名函數名以及任何其他的標識符必須適應一致的大小寫形勢臥龍前端空格和換行并不是的語法內容可有可無建議使用將代碼書寫的更加整潔美觀更有可讀性可選的分號分號可選項語法并不是強制要 第十六天筆記 JavaScript 基礎語法 區分大小寫 JavaScript是一種區分大小寫的語言 JavaScript的關鍵字 變量名 函...
摘要:所以不論你媽媽是喊,狗蛋回家吃飯了,還是喊小明回家吃飯了,其實喊的都是你。當然的嘛狗蛋買了件新衣服,小明當然就有這件新衣服了。。。 上一章--原型鏈講解:傳送門:https://segmentfault.com/a/11... 在上一章講解原型鏈時提到了:所有的引用類型都有一個_proto_屬性,稱之為隱式原型。那么引用類型是什么鬼? 盡量簡單的講解一下javascript中的數據類...
摘要:所以不論你媽媽是喊,狗蛋回家吃飯了,還是喊小明回家吃飯了,其實喊的都是你。當然的嘛狗蛋買了件新衣服,小明當然就有這件新衣服了。。。 上一章--原型鏈講解:傳送門:https://segmentfault.com/a/11... 在上一章講解原型鏈時提到了:所有的引用類型都有一個_proto_屬性,稱之為隱式原型。那么引用類型是什么鬼? 盡量簡單的講解一下javascript中的數據類...
閱讀 939·2021-11-23 09:51
閱讀 998·2021-11-18 10:02
閱讀 1935·2021-09-10 11:27
閱讀 3151·2021-09-10 10:51
閱讀 789·2019-08-29 15:13
閱讀 2072·2019-08-29 11:32
閱讀 2507·2019-08-29 11:25
閱讀 3053·2019-08-26 11:46