JavaScript 定義了幾種數據類型? 哪些是原始類型?哪些是復雜類型?原始類型和復雜類型的區別是什么?
JS數據類型:
1、數值(number):整數和小數(比如1和3.14)
2、字符串(string):字符組成的文本(比如"Hello World")
3、布爾值(boolean):true(真)和false(假)兩個特定值
4、undefined:表示“未定義”或不存在,即此處目前沒有任何值
5、null:表示空缺,即此處應該有一個值,但目前為空
6、對象(object):各種值組成的集合
通常,我們將數值、字符串、布爾值稱為原始類型(primitive type)的值,即它們是最基本的數據類型,不能再細分了。而將對象稱為合成類型(complex type)的值,因為一個對象往往是多個原始類型的值的合成,可以看作是一個存放各種值的容器。至于undefined和null,一般將它們看成兩個特殊值。
原始類型和復雜類型的區別:
- 基本類型變量存的是值,復雜類型的變量存的是內存地址。
- 基本類型在賦值的時候拷貝值,復雜類型在賦值的時候只拷貝地址,不拷貝值。
typeof和instanceof的作用和區別?
typeof 是一個操作符,主要的目的是檢測一個變量是不是基本數據類型的變量,同時也可以說是確定一個變量是字符串,數值,布爾值,還是undefined。數值、字符串、布爾值分別返回number、string、boolean。函數返回function。undefined返回undefined。利用這一點,typeof可以用來檢查一個沒有聲明的變量,而不報錯。
instanceof用于判斷某個變量是否是某個對象的實例,返回值為true或false
如何判斷一個變量是否是數字、字符串、布爾、函數。
可以使用typeof字符。數值、字符串、布爾值分別返回number、string、boolean。
例:
NaN是什么? 有什么特別之處?
NaN含義是Not a Number,表示非數字,NaN和任何值都不相等,包括自己
如何把非數值轉化為數值?
有三個函數可以把非數值轉換為數值
Number()
parseInt()
parseFloat()
Number規則相當復雜而且不合理,幾乎不使用,常用的是后兩個,兩個規則類似
1、忽略字符串前面的空白字符,找到第一個非空白字符
2、如果第一個字符不是-或者數字返回NaN
3、如果是繼續解析,直到非數值模式為止
4、0開頭會當做八進制,0x開頭會當做十六進制,但是可以指定第二個參數指定基數
例:
==與===有什么區別
可以使用==或===判斷兩個值的相等性,===是嚴格意義的相等,只需注意NaN和NaN不等就行了。而使用==的時候,javascript會幫我們做類型轉換,造成一些匪夷所思的結果,那么使用==的時候會在哪些情況下做類型轉換,又會換成什么樣子?
1、如果兩個值類型相同,則執行嚴格相等的運算
2、如果兩個值的類型不同:
如果一個是null,一個是undefined,那么相等
如果一個是數字,一個是字符串,先將字符串轉為數字,然后比較
如果一個值是true/false則將其轉為1/0比較
如果一個值是對象,一個是數字或字符串,則嘗試使用valueOf和toString轉換后比較
其它就不相等了
break與continue有什么區別
break 用于強制退出循環體,執行循環后面的語句
continue 用于退出本次循環,執行下次循環
void 0 和 undefined在使用場景上有什么區別
void運算符的作用是執行一個表達式,然后返回undefined。void 0 比 undefined 占的字節數小,在某些瀏覽器/私有方法中,undefined可以被定義為變量。
如 var undefined = 10;
這種情況會導致常用的空判斷失效。。。。
小練習
以下代碼的輸出結果是?為什么?
console.log(1+1); 輸出2 數字運算
console.log("2"+"4"); 輸出24 字符串拼接
console.log(2+"4"); 輸出24 將數字轉換為字符串然后拼接
console.log(+"4"); 輸出4
以下代碼的輸出結果是?
var a = 1;
a+++a;
typeof a+2;
輸出:3 number2
以下代碼的輸出結果是? 為什么
var a = 1;
var b = 3;
console.log( a+++b );
輸出:4 因為a先賦值然后在自加
遍歷數組,把數組里的打印數組每一項的平方
var arr = [3,4,5]
遍歷 JSON, 打印里面的值
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
以下代碼的輸出結果是?為什么?
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val)
var d = 5;
var data = d ==5 && console.log('bb')
console.log(data)
var data2 = d = 0 || console.log('haha')
console.log(data2)
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)
輸出:
number2 typeof的優先級最高,先計算出a的類型然后在與b進行拼接
bb =的優先級比較會先執行==,但是由于&&,會繼續往后執行,所以輸出bb
undefined
haha =好是右結合。會先計算出||左邊為0,所以后面的也會執行
undefined
2 因為表達式最終轉換成 true+true,即1+1;