2-2.JS基礎(chǔ)

1. JavaScript 定義了幾種數(shù)據(jù)類型? 哪些是原始類型?哪些是復(fù)雜類型?原始類型和復(fù)雜類型的區(qū)別是什么?

js定義了6種原始數(shù)據(jù)類型和對象這種復(fù)雜數(shù)據(jù)類型:

  • 原始數(shù)據(jù)類型
    • 數(shù)值(number):整數(shù)和小數(shù)成洗;
    • 字符串(string):文本數(shù)據(jù);
    • 布爾值(boolean):true和false兩個特定值;
    • undefined:表示“未定義”或不存在点额,即此處目前沒有任何值;
    • null:表示空缺办铡,即此處應(yīng)該有一個值晒杈,但目前為空污桦,一般用作對象的占位符;
    • symbol(ES6)抚笔;
  • 復(fù)雜數(shù)據(jù)類型
    • 對象(object):各種值組成的集合鸽疾;包括數(shù)組(array)、函數(shù)(function)附帽、對象(object)奔则、正則表達(dá)式(regexp)等写半;
  • 區(qū)別
    • 復(fù)雜數(shù)據(jù)類型是多個原始數(shù)據(jù)類型的集合犁柜,原始數(shù)據(jù)類型不能再細(xì)分覆履,不是對象也沒有方法赂鲤。

2. typeof和instanceof的作用和區(qū)別?

文獻(xiàn)
1.MDN instaceof
2.MDN typeof
3.JavaScript instanceof 運(yùn)算符深入剖析

作用:

  • typeof以字符串形式返回操作數(shù)的數(shù)據(jù)類型
//返回"number"
typeof 123
typeof NaN
//"string"
typeof '123'
typeof (typeof 1)
//"boolean"
typeof true
//"function"
typeof function(){}  
//"undefined"
typeof undefined  
//"object"
typeof null 
typeof {a:1} 
typeof [1,2] 
typeof /ss/ 
  • instanceof判斷對象是否為特定的類型
var o = {};
var a = [];
o instanceof Array // false
a instanceof Array // true

function C() {}
var o = new C();
//true
o instanceof C;
//true
o instanceof Object;
  • 區(qū)別:
    typeof:一元運(yùn)算符,返回值為字符串仑鸥,難以判斷object具體類型眼俊;
    instanceof:二元運(yùn)算符院塞,返回值為布爾型,主要用來判斷object是否為特定實例搁拙。

3. 如何判斷一個變量是否是數(shù)字窑业、字符串枕屉、布爾常柄、函數(shù)

如2代碼示例

4. NaN是什么? 有什么特別之處?

NaN(Not a Number):非數(shù)字,不等于自己

NaN == NaN //false

5. 如何把非數(shù)值轉(zhuǎn)化為數(shù)值?

parseInt()轉(zhuǎn)換為整數(shù)、parseFloat()轉(zhuǎn)換為浮點數(shù)西潘、Number()都可以卷玉,但轉(zhuǎn)換整個數(shù)據(jù);

//忽略字符串前空格
//忽略第第一個非數(shù)字后的所有字符
//parseInt('',radix) 可以設(shè)置基數(shù)
//parseInt()     
parseInt('0ab')  //0
parseInt('01a')  //1
parseInt('  0a')  //0
parseInt('0xf1', 10)  //0
parseInt('-1a')  //-1
parseInt('0xf1')  //241十六進(jìn)制不用加基數(shù)
//第一個非空非數(shù)字/±(±后無數(shù)字依然NaN)喷市,返回NaN
parseInt('-a')  
parseInt(null)  
parseInt(true)
parseInt(undefined)
parseInt('a')
----------------------------------------------------
//parseFloat()和parseInt()類似相种,只是會保留小數(shù)部分
parseFloat('-2.1a1a')  //-2.1
----------------------------------------------------
//Number()可以整數(shù)或小數(shù),但會轉(zhuǎn)換整個數(shù)據(jù)东抹;并且會轉(zhuǎn)換null,true,false
Number('1.2')  //1.2
Number('1.2a') //NaN
Number(true)  //1
Number(false)  //0
Number(null)  //0
Number(undefined)  //NaN
Number('a')
//其他
Number('\t\r')   //0 

6. ==與===有什么區(qū)別?

參考文獻(xiàn)
1.JavaScript標(biāo)準(zhǔn)參考教程-阮一峰

== 類型不同蚂子,會先嘗試轉(zhuǎn)換類型再比較沃测;
=== 類型一致缭黔,值相同。

//==相等
//字符串和布爾型比較會轉(zhuǎn)換為數(shù)值蒂破,類型相同不會轉(zhuǎn)換
true == 1  //true
false == 0  //true
true == 'true'  //false,'true'轉(zhuǎn)化為NaN
'' == 0 //true
''==false //true
'' == '0'  //false
-----------------
//undefined與null與其他大多數(shù)比較都是false
undefined == null //true
undefined == 0 //false
null == 0 //false
undefined == false //false
null == false //false
-----------------
//其他
'  \t\t'  == 0   //true
//嚴(yán)格相等
1 === 0x1 // true
+0 === -0  //true
--------
//空對象
{} === {} // false
[] === [] // false
(function (){} === function (){}) // false
//未賦值變量
var a,b
a === b  //true

7. break與continue有什么區(qū)別?

break 跳出循環(huán)馏谨,用于循環(huán)和switch;
continue跳出本次循環(huán)附迷,用于循環(huán)惧互。

8. void 0 和 undefined在使用場景上有什么區(qū)別?

void運(yùn)算一個表達(dá)式,返回defined喇伯,所以void 0 返回undefined喊儡;因為undefined在函數(shù)等中可以作為局部變量賦值,這會使判斷值為undefined失效稻据,所以判斷中使用void 0代替它艾猜。

9.以下代碼的輸出結(jié)果是?為什么?

  • 當(dāng)JavaScript遇到預(yù)期為數(shù)值的地方,就會將參數(shù)值自動轉(zhuǎn)換為數(shù)值捻悯。系統(tǒng)內(nèi)部會自動調(diào)用Number函數(shù)匆赃。
console.log(1+1);      //2  類型相同,都為數(shù)字今缚,直接相加
console.log("2"+"4");  //24  類型相同算柳,都為字符串,直接拼接
console.log(2+"4");    //6   類型不同姓言,一個數(shù)字瞬项,一個字符串,轉(zhuǎn)換為數(shù)字后相加
console.log(+"4");     //4 只有一個字符串運(yùn)算子何荚,也轉(zhuǎn)換為數(shù)字

10.

var a = 1;  
a+++a;  //++優(yōu)先級高于+囱淋,a++先運(yùn)算,后自增,(a++)+a為2兽泣,a也為2
typeof a+2;  //4 typeof優(yōu)先級高绎橘,(type a)+2,type a輸出為"number",數(shù)字和字符串相加称鳞,所以值為“number2”

11.

var a = 1;
var b = 3;
console.log( a+++b );       (a++)+b涮较,a++先運(yùn)算,后自增冈止,為1+3狂票,輸出4

12. 遍歷數(shù)組,打印數(shù)組每一項的平方

var arr = [3,4,5];
for (var i = 0; i <arr.length; i++){
    console.log(arr[i]*arr[i]);
}

13. 遍歷對象, 打印里面的值

var obj = {
 name: 'hunger', 
 sex: 'male', 
 age: 28 
}
for (attr in obj){
  console.log(obj[attr])
}

14.

var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0   //優(yōu)先級typeof , +,  >, || , =
//"number"
//"number2"
//"number2" || true
//或運(yùn)算符(||)的運(yùn)算規(guī)則是:如果第一個運(yùn)算子的布爾值為true熙暴,則返回第一個運(yùn)算子的值闺属,且不再對第二個運(yùn)算子求值;如果第一個運(yùn)算子的布爾值為false周霉,則返回第二個運(yùn)算子的值掂器。
//"number2"
console.log(val)    //"number2"   

var d = 5;
var data = d ==5 && console.log('bb')  //優(yōu)先級 == ,&& , =
//true && console.log('bb')
//打印bb
//因為第一個為true俱箱,所以會返回第二個運(yùn)算子的值
console.log(data)  //undefined

var data2 = d = 0 || console.log('haha')  //優(yōu)先級 || , =  其中=為右結(jié)合
//打印haha
//0 || consloe.log('haha') 
//因為0轉(zhuǎn)換為false国瓮,所以返回第二個運(yùn)算子的值,結(jié)果為undefined
console.log(data2)  //undefined
 
var x = !!"Hello" + (!"world", !!"from here!!"); //優(yōu)先級 ()狞谱!+ ,
//true + (false, true)
//true + true轉(zhuǎn)換為數(shù)值1+1
//2
console.log(x) //2
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末乃摹,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子跟衅,更是在濱河造成了極大的恐慌孵睬,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,639評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件伶跷,死亡現(xiàn)場離奇詭異掰读,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)撩穿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評論 3 385
  • 文/潘曉璐 我一進(jìn)店門磷支,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人食寡,你說我怎么就攤上這事雾狈。” “怎么了抵皱?”我有些...
    開封第一講書人閱讀 157,221評論 0 348
  • 文/不壞的土叔 我叫張陵善榛,是天一觀的道長。 經(jīng)常有香客問我呻畸,道長移盆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,474評論 1 283
  • 正文 為了忘掉前任伤为,我火速辦了婚禮咒循,結(jié)果婚禮上据途,老公的妹妹穿的比我還像新娘。我一直安慰自己叙甸,他們只是感情好颖医,可當(dāng)我...
    茶點故事閱讀 65,570評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著裆蒸,像睡著了一般熔萧。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上僚祷,一...
    開封第一講書人閱讀 49,816評論 1 290
  • 那天佛致,我揣著相機(jī)與錄音,去河邊找鬼辙谜。 笑死俺榆,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的筷弦。 我是一名探鬼主播肋演,決...
    沈念sama閱讀 38,957評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼烂琴!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蜕乡,我...
    開封第一講書人閱讀 37,718評論 0 266
  • 序言:老撾萬榮一對情侶失蹤奸绷,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后层玲,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體号醉,經(jīng)...
    沈念sama閱讀 44,176評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,511評論 2 327
  • 正文 我和宋清朗相戀三年辛块,在試婚紗的時候發(fā)現(xiàn)自己被綠了畔派。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,646評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡润绵,死狀恐怖线椰,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情尘盼,我是刑警寧澤憨愉,帶...
    沈念sama閱讀 34,322評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站卿捎,受9級特大地震影響配紫,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜午阵,卻給世界環(huán)境...
    茶點故事閱讀 39,934評論 3 313
  • 文/蒙蒙 一躺孝、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦植袍、人聲如沸伪很。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽锉试。三九已至,卻和暖如春览濒,著一層夾襖步出監(jiān)牢的瞬間呆盖,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評論 1 266
  • 我被黑心中介騙來泰國打工贷笛, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留应又,地道東北人。 一個月前我還...
    沈念sama閱讀 46,358評論 2 360
  • 正文 我出身青樓乏苦,卻偏偏與公主長得像株扛,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子汇荐,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,514評論 2 348

推薦閱讀更多精彩內(nèi)容