進階任務2

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
*/
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市宣决,隨后出現(xiàn)的幾起案子蘸劈,更是在濱河造成了極大的恐慌,老刑警劉巖尊沸,帶你破解...
    沈念sama閱讀 221,635評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件威沫,死亡現(xiàn)場離奇詭異,居然都是意外死亡洼专,警方通過查閱死者的電腦和手機棒掠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,543評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來屁商,“玉大人烟很,你說我怎么就攤上這事“艏伲” “怎么了溯职?”我有些...
    開封第一講書人閱讀 168,083評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長帽哑。 經(jīng)常有香客問我,道長叹俏,這世上最難降的妖魔是什么妻枕? 我笑而不...
    開封第一講書人閱讀 59,640評論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮粘驰,結果婚禮上屡谐,老公的妹妹穿的比我還像新娘。我一直安慰自己蝌数,他們只是感情好愕掏,可當我...
    茶點故事閱讀 68,640評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著顶伞,像睡著了一般饵撑。 火紅的嫁衣襯著肌膚如雪剑梳。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,262評論 1 308
  • 那天滑潘,我揣著相機與錄音垢乙,去河邊找鬼。 笑死语卤,一個胖子當著我的面吹牛追逮,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播粹舵,決...
    沈念sama閱讀 40,833評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼钮孵,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了眼滤?” 一聲冷哼從身側(cè)響起油猫,我...
    開封第一講書人閱讀 39,736評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎柠偶,沒想到半個月后情妖,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,280評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡诱担,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,369評論 3 340
  • 正文 我和宋清朗相戀三年毡证,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蔫仙。...
    茶點故事閱讀 40,503評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡料睛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出摇邦,到底是詐尸還是另有隱情恤煞,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布施籍,位于F島的核電站居扒,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏丑慎。R本人自食惡果不足惜喜喂,卻給世界環(huán)境...
    茶點故事閱讀 41,870評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望竿裂。 院中可真熱鬧玉吁,春花似錦、人聲如沸腻异。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,340評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽悔常。三九已至影斑,卻和暖如春给赞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背鸥昏。 一陣腳步聲響...
    開封第一講書人閱讀 33,460評論 1 272
  • 我被黑心中介騙來泰國打工塞俱, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人吏垮。 一個月前我還...
    沈念sama閱讀 48,909評論 3 376
  • 正文 我出身青樓障涯,卻偏偏與公主長得像,于是被迫代替她去往敵國和親膳汪。 傳聞我的和親對象是個殘疾皇子唯蝶,可洞房花燭夜當晚...
    茶點故事閱讀 45,512評論 2 359

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