1. JavaScript 定義了幾種數(shù)據(jù)類型?哪些是原始類型?哪些是復雜類型?原始類型和復雜類型的區(qū)別是什么?
1.1 JavaScript 定義了六種數(shù)據(jù)類型?
- 數(shù)值(number):整數(shù)和小數(shù)(比如1和3.14)
- 字符串(string):字符組成的文本(比如"Hello World")
- 布爾值(boolean):true(真)和false(假)兩個特定值
- undefined:表示“未定義”或不存在匿垄,即此處目前沒有任何值
- null:表示空缺,即此處應該有一個值血淌,但目前為空
- 對象(object):各種值組成的集合
1.2 哪些是原始類型?哪些是復雜類型?
- 數(shù)值稽穆、字符串逗噩、布爾值稱為原始類型(primitive type)的值穆咐,即它們是最基本的數(shù)據(jù)類型,不能再對齊進行細分
- 對象為復雜類型(complex type)的值灾常,一個對象往往是多個原始類型的值的合成照激,可以看作是一個存放各種值的容器发魄。
- undefined和null,一般將它們看成兩個特殊值俩垃。
對象又可以細分為三個子類型:
- 狹義的對象(object)
- 數(shù)組(array)
- 函數(shù)(function)
- 正則表達式 (regexp)
1.3 原始類型和復雜類型的區(qū)別是什么?
1.3.1 特性區(qū)別:
- 原始值是固定而簡單的值,是存放在棧(stack)中的簡單數(shù)據(jù)段,也就是說,它們的值直接存儲在變量訪問的位置.原始值是表示Javascript中可用的數(shù)據(jù)或信息的最底層形式或最簡單形式励幼。原始類型的值被稱為原始值,是因為它們是不可細化的口柳。也就是說苹粟,數(shù)字是數(shù)字,字符是字符跃闹,布爾值則是true或false嵌削,null和undefined就是null和undefined毛好。這些值本身很簡單,不能表示由其他值組成的值
- 復雜值可以由很多不同類型的javascript對象組成苛秕。復雜對象其在內(nèi)存中的大小是未知的肌访,因為復雜對象可以包含任何值,而不是一個特定的已知值艇劫,
1.3.2 存儲方式區(qū)別
- 原始值占據(jù)空間固定吼驶,是簡單的數(shù)據(jù)段,為了便于提升變量查詢速度店煞,將其存儲在棧(stack)中
- 由于復雜值的大小會改變蟹演,所以不能將其存放在棧中,否則會降低變量查詢速度顷蟀,因此其存儲在堆(heap)中酒请,存儲在變量處的值是一個指針,指向存儲對象的內(nèi)存處
1.3.3 訪問方式的區(qū)別
- 按值訪問
原始值是作為不可細化的值進行存儲和操作的鸣个,引用它們會轉(zhuǎn)移其值 - 引用訪問
復雜值是通過引用進行存儲和操作的羞反,而不是實際的值。創(chuàng)建一個包含復雜對象的變量時毛萌,其值是內(nèi)存中的一個引用地址苟弛。引用一個復雜對象時喝滞,使用它的名稱(即變量或?qū)ο髮傩?通過內(nèi)存中的引用地址獲取該對象值
1.3.4 比較方式的區(qū)別
- 原始值采用值比較阁将,而復雜值采用引用比較。復雜值只有在引用相同的對象(即有相同的地址)時才相等右遭。即使是包含相同對象的兩個變量也彼此不相等做盅,因為它們并不指向同一個對象
1.3.5 動態(tài)屬性的區(qū)別
- 對于復雜值枚荣,可以為其添加屬性和方法阅茶,也可以改變和刪除其屬性和方法;但簡單值不可以添加屬性和方法
復雜值支持動態(tài)對象屬性畏吓,因為我們可以定義對象滚婉,然后創(chuàng)建引用图筹,再更新對象,并且所有指向該對象的變量都會獲得更新让腹。一個新變量指向現(xiàn)有的復雜對象远剩,并沒有復制該對象。這就是復雜值有時被稱為引用值的原因骇窍。復雜值可以根據(jù)需求有任意多個引用瓜晤,即使對象改變,它們也總是指向同一個對象
1.3.6 包裝類型的區(qū)別
- 原始值被當作構造函數(shù)創(chuàng)建的一個對象來使用時腹纳,Javascript會將其轉(zhuǎn)換成一個對象痢掠,以便可以使用對象的特性和方法驱犹,而后拋棄對象性質(zhì),并將它變回到原始值
2. typeof和instanceof的作用和區(qū)別?
2.1 typeof運算符可以返回一個值的數(shù)據(jù)類型足画,可能有以下結果雄驹。
- 原始類型: 數(shù)值、字符串淹辞、布爾值分別返回number荠医、string、boolean桑涎。
- 函數(shù): 返回function
- undefined: 返回undefined彬向。
- 除此以外,其他情況都返回object
2.2 instanceof的作用
instanceof用于判斷某個變量是否是某個對象的實例攻冷,返回值為true或false
3. 如何判斷一個變量是否是數(shù)字娃胆、字符串、布爾等曼、函數(shù)
typeof 變量名
如果返回值為number, 表示變量為數(shù)值里烦;
如果返回值為string, 表示變量為字符串;
如果返回值為boolean, 表示變量為布爾運算禁谦;
如果返回值為function, 表示變量為函數(shù)胁黑;
4. NaN是什么? 有什么特別之處?
NaN含義是Not a Number,表示變量類型為數(shù)值的非數(shù)字州泊;
NaN和任何值都不相等丧蘸,包括自己
5. 如何把非數(shù)值轉(zhuǎn)化為數(shù)值?
有三個函數(shù)可以把非數(shù)值轉(zhuǎn)換為數(shù)值
- Number()
- parseInt()
- parseFloat()
其中利用parseInt()及parseFloat()進行轉(zhuǎn)換是會按照以下規(guī)則: - 忽略字符串前面的空白字符,找到第一個非空白字符
- 如果第一個字符不是-或者數(shù)字返回NaN
- 如果是繼續(xù)解析遥皂,直到非數(shù)值模式為止
- 0開頭會當做八進制力喷,0x開頭會當做十六進制,但是可以指定第二個參數(shù)指定基數(shù)
6. " == "與 " === " 有什么區(qū)別
相等運算符" == "比較兩個值是否相等演训,嚴格相等運算符" === "比較它們是否為“同一個值”弟孟。如果兩個值不是同一類型,嚴格相等運算符" === "直接返回false样悟,而相等運算符" == "會將它們轉(zhuǎn)化成同一個類型拂募,再用嚴格相等運算符進行比較。
7. break與continue有什么區(qū)別
- break語句用于跳出代碼塊或循環(huán)窟她。執(zhí)行該代碼塊或循環(huán)的之后的內(nèi)容
- continue語句用于立即終止本輪循環(huán)陈症,返回循環(huán)結構的頭部,開始下一輪循環(huán)的執(zhí)行
8. void 0 和 undefined在使用場景上有什么區(qū)別
void運算符的作用是執(zhí)行一個表達式礁苗,然后不返回任何值爬凑,或者說返回undefined。
在函數(shù)中试伙,undefined可以被賦值嘁信,此時如果需要判斷一個變量為undefined于样,可以采用 "變量 = void 表達式"的方式來判斷
9. 以下代碼的輸出結果是?為什么?
console.log(1+1); // 2
console.log("2"+"4"); // 24
console.log(2+"4"); // 24
console.log(+"4"); // 4
10. 以下代碼的輸出結果是?
var a = 1; //聲明變量 a,且a = 1;
a+++a; // (a++)+a=1 + 2 = 3
typeof a+2; // (typeof a)+2 = "number"+2 = number2
11. 以下代碼的輸出結果是? 為什么
var a = 1; // 變量 a = 1
var b = 3; // 變量 b = 3
console.log( a+++b ); // a+++b=(a++)+b=1 + 3 = 4, a=2, b=3
12. 遍歷數(shù)組var arr = [3,4,5]潘靖,把數(shù)組里的打印數(shù)組每一項的平方
for(var i=0; i<arr.length; i++) {
console.log(arr[i]*arr[i])
}
13. 遍歷 JSON, 打印里面的值
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
for(var key in obj){
console.log(obj[key])
}
14. 以下代碼輸出結果是? 為什么 (選做題目)
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) // number2
/*
val = ((typeof a) + b) || (c >0)
number2 || true
第一個運算子值為字符串穿剖,true,返回第一個運算子的值卦溢,即 number2
*/
var d = 5;
var data = (d ==5) && console.log('bb')
console.log(data) // bb
/*
var data = (d ==5) && console.log('bb')
(d ==5)運算值為true糊余,data返回第二個運算子的值,即bb
*/
var data2 = d = 0 || console.log('haha')
console.log(data2) // haha
/*
data2 = d = 0 || console.log('haha')
data2 = 0, 布爾運算false单寂,正式返回第二個運算子的值贬芥,即 haha
*/
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x) // 2
/*
true + ( false, true)
true + true
返回值 2
*/