JS數(shù)據(jù)類型.運(yùn)算符.流程控制語句

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

六種

  • 數(shù)值(number):整數(shù)和小數(shù)
  • 字符串(string):字符組成的文本
  • 布爾值(boolean):true(真)和false(假)
  • undefined:表示“未定義”或不存在,即此處目前沒有任何值
  • unll:表示空缺宙彪,即此處應(yīng)該有一個(gè)值释漆,但目前為空
  • 對象(object):各種值組成的集合篮迎。對象有三個(gè)子類型狹義的對象(object),數(shù)組(array)逊笆,函數(shù)(function),正則表達(dá)式
    數(shù)值岂傲、字符串、布爾值稱為原始類型(primitive type)的值差牛,即它們是最基本的數(shù)據(jù)類型堰乔,不能再細(xì)分了镐侯。
    將對象稱為復(fù)雜類型(complex type)的值苟翻,因?yàn)橐粋€(gè)對象往往是多個(gè)原始類型的值的合成骗污,可以看作是一個(gè)存放各種值的容器。
    至于undefined和null诅炉,一般將它們看成兩個(gè)特殊值。

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

typeof運(yùn)算符可以返回一個(gè)值的數(shù)據(jù)類型月而,可能有以下結(jié)果父款。

1.原始類型
    數(shù)值瞻凤、字符串阀参、布爾值分別返回number、string包晰、boolean炕吸。
    typeof 123 // "number"
    typeof '123' // "string"
    typeof false // "boolean"
2.函數(shù)
    函數(shù)返回function。
    function f() {}
    typeof f // "function"
3.undefined
    undefined返回undefined树肃。
    typeof undefined // "undefined"
4.其他
    除此以外胸嘴,其他情況都返回object斩祭。
    typeof window // "object"
    typeof {} // "object"
    typeof [] // "object"
    typeof null // "object"

instanceof用于判斷一個(gè)變量是否某個(gè)對象的實(shí)例妙色,運(yùn)算符返回一個(gè)布爾值盆顾。instanceof只能用來判斷對象和函數(shù),不能用來判斷字符串和數(shù)字等坏挠。

區(qū)分?jǐn)?shù)組和對象
var o = {};
var a = [];
o instanceof Array // false
a instanceof Array // true

3.如何判斷一個(gè)變量是否是數(shù)字降狠、字符串对竣、布爾庇楞、函數(shù)

typeof 123 // "number"
typeof '123' // "string"
typeof false // "boolean"
 function f() {}
typeof f // "function"

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

NaN含義是Not a Number,表示非數(shù)字柏肪,NaN和任何值都不相等姐刁,包括自己

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

1.Number()
2.parseInt()
3.parseFloat()

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

=== 嚴(yán)格意義的相等,只需注意NaN和NaN不等就行了烦味。
== 值相等聂使,javascript會做類型轉(zhuǎn)換,
如果兩個(gè)值類型相同谬俄,則執(zhí)行嚴(yán)格相等的運(yùn)算
如果兩個(gè)值的類型不同
如果一個(gè)是null柏靶,一個(gè)是undefined,那么相等
如果一個(gè)是數(shù)字溃论,一個(gè)是字符串屎蜓,先將字符串轉(zhuǎn)為數(shù)字,然后比較
如果一個(gè)值是true/false則將其轉(zhuǎn)為1/0比較
如果一個(gè)值是對象钥勋,一個(gè)是數(shù)字或字符串炬转,則嘗試使用valueOf和toString轉(zhuǎn)換后比較
其它就不相等了

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

break 用于強(qiáng)制退出循環(huán)體,執(zhí)行循環(huán)后面的語句
continue 用于退出本次循環(huán),執(zhí)行下次循環(huán)

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

void 會執(zhí)行后面的表達(dá)式并返回 undefined,undefined在JavaScript中并不屬于保留字/關(guān)鍵字先煎,某些情境下undefined是可以被賦值的谤绳,比如在函數(shù)中,這樣的話就不能用undefined來進(jìn)行判斷了

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

console.log(1+1);//2,兩個(gè)都是數(shù)字直接相加    
console.log("2"+"4");  //“24”,兩個(gè)都是字符串進(jìn)行拼接
console.log(2+"4"); //“24”婿失,只有一個(gè)是字符串,會對另一個(gè)轉(zhuǎn)換成字符串進(jìn)行拼接
console.log(+"4");//4飘弧,單獨(dú)一個(gè)字符串會對進(jìn)行數(shù)字轉(zhuǎn)換

10. 以下代碼的輸出結(jié)果是?

var a = 1;  
a+++a;  //3, a++的優(yōu)先級比+a大冠王,a++先賦值再計(jì)算,此時(shí)a++為1,但+a此時(shí)已經(jīng)為2吓蘑,結(jié)果為3
typeof a+2;//"number2" typeof的優(yōu)先級比+大琳猫,typeof 2返回字符串"number" 與2進(jìn)行字符串拼接,變成“number2”

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

 var a = 1;
 var b = 3;
 console.log( a+++b );//4,a++優(yōu)先級比+大,a++此時(shí)為1匀奏,與b計(jì)算得4

12.遍歷數(shù)組,把數(shù)組里的打印數(shù)組每一項(xiàng)的平方

var arr = [3,4,5]

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

得到9 16 25

13. 遍歷 JSON, 打印里面的值

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

得到hunger male 28

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

var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) //"number2"   typeof a+b為"number2",而或運(yùn)算當(dāng)?shù)谝粋€(gè)表達(dá)式為true,無論“||”后面是true還是false,結(jié)果都返回“||”前面的值滥搭,則返回第一個(gè)表達(dá)式的值栽惶。

var d = 5;
var data = d ==5 && console.log('bb')
console.log(data)//"bb",只要“&&”兩個(gè)都為true汁蝶,返回第二個(gè)表達(dá)式的值,第一個(gè)為false耻讽,則都不返回

var data2 = d = 0 || console.log('haha')
console.log(data2)//"haha",第一個(gè)為false慰枕,看第二個(gè)值,第二個(gè)為true拔稳,返回第二個(gè)表達(dá)式的值
 
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//2 !!"Hello"為true巴比, (!"world", !!"from here!!")轉(zhuǎn)換為(false,true),(x,y)類型返回第二個(gè)值术奖,返回true政勃,true+true丸冕,boolean轉(zhuǎn)換為數(shù)字佩番,即1+1=2.
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市持际,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,348評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡细疚,警方通過查閱死者的電腦和手機(jī)啦鸣,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,122評論 2 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來换帜,“玉大人楔壤,你說我怎么就攤上這事」咄眨” “怎么了蹲嚣?”我有些...
    開封第一講書人閱讀 156,936評論 0 347
  • 文/不壞的土叔 我叫張陵递瑰,是天一觀的道長。 經(jīng)常有香客問我隙畜,道長抖部,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,427評論 1 283
  • 正文 為了忘掉前任议惰,我火速辦了婚禮您朽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘换淆。我一直安慰自己,他們只是感情好几颜,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,467評論 6 385
  • 文/花漫 我一把揭開白布倍试。 她就那樣靜靜地躺著,像睡著了一般蛋哭。 火紅的嫁衣襯著肌膚如雪县习。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,785評論 1 290
  • 那天谆趾,我揣著相機(jī)與錄音躁愿,去河邊找鬼。 笑死沪蓬,一個(gè)胖子當(dāng)著我的面吹牛彤钟,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播跷叉,決...
    沈念sama閱讀 38,931評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼逸雹,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了云挟?” 一聲冷哼從身側(cè)響起梆砸,我...
    開封第一講書人閱讀 37,696評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎园欣,沒想到半個(gè)月后帖世,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,141評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沸枯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,483評論 2 327
  • 正文 我和宋清朗相戀三年日矫,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片绑榴。...
    茶點(diǎn)故事閱讀 38,625評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡搬男,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出彭沼,到底是詐尸還是另有隱情缔逛,我是刑警寧澤,帶...
    沈念sama閱讀 34,291評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站褐奴,受9級特大地震影響按脚,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜敦冬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,892評論 3 312
  • 文/蒙蒙 一辅搬、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧脖旱,春花似錦堪遂、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至践险,卻和暖如春猿妈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背巍虫。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工彭则, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人占遥。 一個(gè)月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓俯抖,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瓦胎。 傳聞我的和親對象是個(gè)殘疾皇子蚌成,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,492評論 2 348

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