JavaScript 定義了幾種數(shù)據(jù)類型? 哪些是原始類型?哪些是復(fù)雜類型?原始類型和復(fù)雜類型的區(qū)別是什么?
JavaScript語(yǔ)言的每一個(gè)值皿渗,都屬于某一種數(shù)據(jù)類型轻腺。JavaScript的數(shù)據(jù)類型,共有七種挤土。
數(shù)值(number):整數(shù)和小數(shù)(比如1和3.14)
字符串(string):字符組成的文本(比如"Hello World")
布爾值(boolean):true(真)和false(假)兩個(gè)特定值
undefined:表示“未定義”或不存在仰美,即此處目前沒有任何值
null:表示空缺咖杂,即此處應(yīng)該有一個(gè)值懦尝,但目前為空
對(duì)象(object):各種值組成的集合
symbol:一種特殊的、不可變的數(shù)據(jù)類型伍绳,可以作為對(duì)象屬性的標(biāo)識(shí)符使用。
其中止毕,數(shù)值漠趁、字符串和布爾值是原始類型谨朝,對(duì)象為復(fù)雜類型字币。
原始類型和復(fù)雜類型的區(qū)別:原始類型是最基本的數(shù)據(jù)類型洗出,不能再細(xì)分图谷;將對(duì)象稱為復(fù)雜類型(complex type)的值便贵,因?yàn)橐粋€(gè)對(duì)象往往是多個(gè)原始類型的值的合成利耍,可以看作是一個(gè)存放各種值的容器。
undefined和null可以看成兩個(gè)特殊的值程癌。
typeof和instanceof的作用和區(qū)別?
typeof的作用:typeof 是用于返回一個(gè)數(shù)據(jù)其原始的數(shù)據(jù)類型,對(duì)于常見的幾大數(shù)據(jù)類型都可以用typeof 數(shù)據(jù)類型的方式進(jìn)行判斷。
typeof是一元運(yùn)算符郎仆,返回值為字符串抛寝,該字符串用來說明運(yùn)算數(shù)的數(shù)據(jù)類型盗舰。
用來獲取運(yùn)算數(shù)的數(shù)據(jù)類型。返回的值有number蛮位、boolean、undefined们何、function拂封、object烘苹、string。
console.log(typeof(1));//number
console.log(typeof(true));//boolean
console.log(typeof("abc"));//string
console.log(typeof({}));//object
console.log(typeof(m));//undefined
console.log(typeof(function(){})) //function
instanceof的作用:instance 是用于判斷某個(gè)對(duì)象是不是構(gòu)造函數(shù)的一個(gè)實(shí)例廊鸥,舉例來說就是一個(gè)新聲明的變量是不是調(diào)用了構(gòu)造函數(shù)的內(nèi)置屬性或方法.
instanceof用于判斷某個(gè)變量是否是某個(gè)對(duì)象的實(shí)例,返回值為true或false。
區(qū)別:
typeof能夠判斷原始類型和undefined酥宴、function授滓,但是不能用來判斷對(duì)象類型和null,因?yàn)槎紩?huì)返回object诚啃。
還可以利用typeof來判斷變量是否存在噩咪,不能直接使用if(a),因?yàn)槿绻鸻沒有聲明就會(huì)報(bào)錯(cuò)筋搏。
if (typeof a === 'undefined') {
//a不存在
}
instanceof運(yùn)算符時(shí)js語(yǔ)言中原生的用來判斷實(shí)例繼承關(guān)系的操作符奔脐。判斷一個(gè)實(shí)例是否屬于某種類型峦朗,所以只能判斷對(duì)象和函數(shù)波势,不能判斷字符串和數(shù)字拴曲。
function Foo(){}
var foo = new Foo();
console.log(foo instanceof Foo); //true
如何判斷一個(gè)變量是否是數(shù)字、字符串叁熔、布爾、函數(shù)
用typeof
即可
NaN是什么? 有什么特別之處?
typeof NaN // 'number'
NAN字面上是 not a number驹马,即表示這個(gè)變量聲明的數(shù)據(jù)類型不是一個(gè)number類型的數(shù)據(jù),它是一個(gè)數(shù)字類型册踩。
特別之處在于任何NaN的值進(jìn)行操作都會(huì)返回一個(gè)NaN暂吉,其次阎肝,NaN與任何值都不相等即NaN === NaN也是false.
如何把非數(shù)值轉(zhuǎn)化為數(shù)值?
三個(gè)方法:
Number('233')
//233
parseInt('233')
//233
parseFloat('233')
//233
==與===有什么區(qū)別
==是近似相等嫉父,===是完全相等摇肌,==會(huì)進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換昵骤,===不會(huì),功能上也不同,==是比較數(shù)值等于或否雨饺,===是數(shù)據(jù)類型與數(shù)值比較是否相等即全等。
break與continue有什么區(qū)別
break是指當(dāng)條件滿足或被觸發(fā)后直接終止所有循環(huán)移斩,即便后面的內(nèi)容并沒有完全執(zhí)行完。
continue是指當(dāng)條件觸發(fā)后跳過當(dāng)前循環(huán)繼續(xù)下一循環(huán),并輸出在次之前和之后的所有結(jié)果朱躺。
void 0 和 undefined在使用場(chǎng)景上有什么區(qū)別
undefined可以在局部作用域中被覆寫长搀,而void運(yùn)算返回都是undefined轿钠,因此當(dāng)undefined被改寫的時(shí)候症汹,可以用 void 0代替背镇。
以下代碼的輸出結(jié)果是?為什么?
console.log(1+1); //2 1和1都是數(shù)字
console.log("2"+"4"); //24 '2'破婆、'4'都是字符串
console.log(2+"4"); //24 2是數(shù)字,4是‘字符串’
console.log(+"4");//4 只有一個(gè)參數(shù)會(huì)返回該參數(shù)的正數(shù)值
以下代碼的輸出結(jié)果是?
var a = 1;
a+++a;
typeof a+2;
因?yàn)?+的優(yōu)先級(jí)比+高裳扯,所以該語(yǔ)句可改為(a++)+a;
;
a++
之后a變?yōu)?谤职,此時(shí)a++
的結(jié)果返回依舊是1,然后1+2冤吨,該語(yǔ)句變?yōu)?饶套。因?yàn)閠ypeof優(yōu)先級(jí)比+高,因此先執(zhí)行typeof a
然后返回number
,然后'number' + 2
,所以這三個(gè)語(yǔ)句最后返回'number2'
以下代碼的輸出結(jié)果是? 為什么
var a = 1;
var b = 3;
console.log( a+++b );
++運(yùn)算符的優(yōu)先級(jí)別大于+,因此該表達(dá)式可更改為(a++)+b;
a++的結(jié)果依然是1,1+3爆安,所以最后打印的是4
在這里總結(jié)一下a++和++a
a=100;
b=a++;
console.log(a,b)//101 100 a變了仔引,a的結(jié)果沒變
a=100;
b=++a;
console.log(a,b)//101 101 a變了,b的結(jié)果也變了
同異:
相同:a都變了翘簇,差異:a的結(jié)果(b)一個(gè)沒變儿倒,一個(gè)變了
遍歷數(shù)組,把數(shù)組里的打印數(shù)組每一項(xiàng)的平方
var arr = [3,4,5]
for(var i=0;i<arr.length;i++){
//以下兩個(gè)皆可打印出正確答案
//console.log(arr[i]*arr[i]);
console.log(Math.pow(arr[i],2));
}
遍歷 JSON, 打印里面的值
var obj = {
name: 'hunger',
sex: 'male',
age: 28
}
for(i in obj){
console.log(obj[i]);
}
以下代碼輸出結(jié)果是? 為什么 (選做題目)
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val)
//考察的優(yōu)先級(jí)彻犁,由優(yōu)先級(jí)可將該表達(dá)式改為var val = ((typeof a) + b) || (c>0);因此val可以清晰的看出來為var val = 'number2' || true;
因此val為'number2'
var d = 5;
var data = d ==5 && console.log('bb') //'bb'
console.log(data)// undefined
//依然考察的優(yōu)先級(jí)凰慈,該表達(dá)式可改為var data = (d ==5) && console.log('bb'),此時(shí)就執(zhí)行console.log('bb')打印出'bb'了森篷,同事console.log('bb')返回undefined,undefined被賦值給d和data,因此最后打印data是undefined
var data2 = d = 0 || console.log('haha')//'haha'
console.log(data2)//undefined
//只能說是考察||這個(gè)運(yùn)算符了,因?yàn)閨|運(yùn)算符左邊為0蛀恩,因此取值右邊席揽,然后就打印'haha'了,console.log('haha')返回undefined,然后undefined被賦值給data2属桦,因此最后打印出undefined了
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//2
//考察的是取反運(yùn)算符號(hào)系谐,!是取反茶袒,然后強(qiáng)制將數(shù)值轉(zhuǎn)換為布爾值句喜,!!同樣是將數(shù)值轉(zhuǎn)換為布爾值,但他并沒有取反。還有一個(gè)逗號(hào)運(yùn)算符,取钠至,后面那個(gè)值宪卿,因此該語(yǔ)句可寫為var x = true + true,則x就被賦值為2了
因?yàn)槊總€(gè)console.log()會(huì)返回undefined,就不重復(fù)說明了