15. 數(shù)據(jù)類型、運算符碱茁、流程控制語句

JavaScript 的數(shù)據(jù)類型

  • JavaScript語言的每一個值裸卫,都屬于某一種數(shù)據(jù)類型。JavaScript的數(shù)據(jù)類型共有6種纽竣。
    • 數(shù)值(number):整數(shù)和小數(shù)
    • 字符串(string):字符組成的文本(例如:"Hello World")
    • 布爾值(boolean):true(真)和false(假)兩個特定值
    • undefined:表示“未定義”或不存在墓贿,即此處目前沒有任何值
    • null:表示空缺,即此處應(yīng)有一個值蜓氨,但目前為空
    • 對象(object):各種值組成的集合
  • 原始類型
    number聋袋、string、boolean稱為原始類型的值穴吹,即他們是最基本的數(shù)據(jù)類型幽勒,不能在細分。
  • 復(fù)雜類型
    對象(object)則被稱為復(fù)雜類型港令,因為一個對象往往是多個原始類型值的合成啥容,可以看作是一個存放各種值的容器。其可以細分成Object 類型顷霹、Array 類型咪惠、Date 類型、RegExp 類型淋淀、Function 類型等遥昧。
  • 二者區(qū)別
    • 原始類型:
      a.最基本的數(shù)據(jù)類型,不能再細分朵纷,數(shù)據(jù)存放在棧內(nèi)存里炭臭。
      b.基本類型的比較是值的比較。
      c.變量存放在棧內(nèi)存(stack)里袍辞。
    • 復(fù)雜類型:
      a.一個對象往往是多個原始類型值的合成徽缚,是一組數(shù)據(jù)和功能的集合。
      b.引用類型的比較是引用的比較革屠。
      c.數(shù)據(jù)同時存放在棧內(nèi)存和堆內(nèi)存里凿试,棧內(nèi)存中保存了變量標識符和指向內(nèi)存中該對象的指針,堆內(nèi)存中保存了對象的內(nèi)容似芝。

typeof和instanceof的作用與區(qū)別

  • typeof用于基本數(shù)據(jù)類型的類型判斷那婉,返回值都為小寫的字符串。如果是對象党瓮,除了function類型會返回“function”, 其他對象統(tǒng)一返回“object”详炬。
typeof  123  \\ number
typeof  "abc"  \\ string
typeof  false  \\ boolean
function  f( ) { }
typeof  f  \\ funtcion
typeof  { }  \\ object
typeof  null  \\ object
typeof  undefined  \\ undefined

typeof應(yīng)該注意的問題:
使用typeof操作符的時候,如果檢測對象是函數(shù),那么操作符返回"function" 呛谜。如果檢測對象是正則表達式的時候在跳,在Safari和Chrome中使用typeof的時候會錯誤的返回"function",其他的瀏覽器返回的是object隐岛。

  • instanceof 利用原型鏈繼承關(guān)系做判斷猫妙,它針對對象類型(語法:對象 instanceof 構(gòu)造函數(shù))
var o = { };
var a = { };
o instanceof Array // false
a instanceof Array // true
>   [1,2,3] instanceof Array
<  ture
>  var obj = { }
<  undefined
>  obj instanseof Array
<  false
  • 區(qū)別
    • typeof是判斷變量是什么基本類型的
    • instanceof是判斷對象到底是什么類型的
  • typeof undefined 范例
    eg:
    沒有聲明a、b時聚凹,
>  a+b
報錯割坠;
然而
>  typeof  b
<  "undefined"
**利用這一點,typeof可以用來檢查一個沒有聲明的變量妒牙,而不報錯**

實際編程中彼哼,這個特點通常用在判斷語句:

//  錯誤的寫法
if  (v) { }    //報錯

//  正確的寫法
if  (typeof v === "undefined") { }
不管 v 是否存在,都不報錯

如何判斷一個變量是否是數(shù)字湘今、字符串敢朱、布爾、函數(shù)

使用typeof摩瞎,看返回值

NaN

NaN含義是Not a Number蔫饰,表示非數(shù)字,NaN和任何值都不相等愉豺,包括自己。

NaN == NaN;   // false
parseInt('abc');  // NaN

非數(shù)值轉(zhuǎn)化為數(shù)值

  • 有三個函數(shù)可以把非函數(shù)轉(zhuǎn)換為數(shù)值
    • Number( )
    • parseInt( )
    • parseFloat( )
  • Number( ):將任何類型的值轉(zhuǎn)化為數(shù)值茫因。但Number規(guī)則相當復(fù)雜而且不合理
    轉(zhuǎn)換規(guī)則如下:
    • 如果是Boolean值蚪拦,true和false分別轉(zhuǎn)化為1和0
    • 如果是數(shù)字,只是簡單的傳入和返回
    • 如果是null, 返回0
    • 如果是undefined, 返回NaN
    • 如果是如果是字符串冻押,按照下面的規(guī)則:
      • 如果只包含數(shù)字,則將其轉(zhuǎn)化為十進制驰贷。
      • 如果數(shù)字中包含浮點格式,比如‘1.1’轉(zhuǎn)化為1.1
      • 如果包含有效的十六進制洛巢,比如‘0xf’轉(zhuǎn)化為15
      • 如果字符串是空的(不包含任何字符)轉(zhuǎn)化為0
      • 如果包含上述其他的格式轉(zhuǎn)化為NaN
    • 如果是對象括袒,則調(diào)用對象的valueOf()方法,依照前面的規(guī)則轉(zhuǎn)化稿茉,如果結(jié)果為NaN锹锰,則調(diào)用對象的toString()方法,再次按照前面的方法轉(zhuǎn)換返回的字符串
number (false) //  0
number (true) //  1
number (123) //  123
number (null) //  0
number (undefined) //  NaN
number (0xe) //  14
number (" ") //  0
number ({toString:function( ){return '123'; }}) //  123
number ({valueOf:function( ){return 456; }}) //  456
  • parseInt( )和parseFloat( )
    • parseInt( ) :把值轉(zhuǎn)換成整數(shù)
    • parseFloat( ):把值轉(zhuǎn)換成浮點數(shù)
    • 使用規(guī)則:
      • 忽略字符串前面的空白字符漓库,找到第一個非空白字符
      • 如果第一個字符不是-或者數(shù)字恃慧,返回NaN
      • 如果是繼續(xù)解析,知道非數(shù)值模式為止
      • 0開頭會當做八進制渺蒿,0x開頭會當做十六進制痢士,但是可以制定第二個參數(shù)制定基數(shù)
parseInt('blue'); //  NaN
parseInt('-23ABS'); //  -23
parseInt('0xf1'); //  241
parseInt('101',2); //  5

==與===的區(qū)別

  • === : 嚴格相等(全等操作符),兩個被比較的值在比較前都不進行隱式轉(zhuǎn)換茂装。若兩者類型不同怠蹂,則值不相等善延。
  • ==: 非嚴格相等(相等操作符),在比較前將兩個被比較的值轉(zhuǎn)換為相同類型城侧。
  • 一般來說易遣,使用全等操作符總是對的,因為全等操作符的結(jié)果更容易預(yù)測赞庶,并且因為沒有隱式轉(zhuǎn)換训挡,全等比較的操作會更快。

break與continue的區(qū)別

  • break用于強制退出循環(huán)體歧强,執(zhí)行循環(huán)后面的語句
for (var i=1 ; i<10 ; i++) {
     if (i % 4 ===0) {
         break;
     }
     console.log(i);
}              // 1,2,3
  • continue用于退出本次循環(huán)澜薄,執(zhí)行下次循環(huán)
for (var i=1 ; i<10 ; i++) {
     if(i % 4 ===0) {
        continue;
     }
     console.log(i);
}              // 1,2,3,5,6,7,9

void 0 和 undefined在使用場景上的區(qū)別

undefined可以在局部作用域中被重寫,
而void運算返回值都是undefined摊册。

function fn() {
    var undefined = 3;
    var a;
    if { a===undefined }{
        console.log('===')
    } else {
        console.log('!==')
    }
}
fn()           // !==
function fn() {
    var undefined = 3;
    var a;
    if { a===void 0 }{
        console.log('===')
    } else {
        console.log('!==')
    }
}
fn()           // ===

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

console.log(1+1);      //2茅特,數(shù)字相加
console.log("2"+"4");        //"24"忘分,字符串拼接
console.log(2+"4");       //"24",類型不同白修,轉(zhuǎn)換為字符串妒峦,拼接
console.log(+"4");      //4,字符串轉(zhuǎn)換為數(shù)字
  • 加法運算符對不同的數(shù)據(jù)類型有不同的含義
    • 在兩個操作數(shù)都是數(shù)字的時候兵睛,會做加法運算
    • 兩個參數(shù)都是字符串或在有一個參數(shù)是字符串的情況下會把另外一個參數(shù)轉(zhuǎn)換為字符串做字符串拼接
    • 在參數(shù)有對象的情況下會調(diào)用其valueOf或toString
    • 在只有一個字符串參數(shù)的時候會嘗試將其裝換為數(shù)字
    • 在只有一個數(shù)字參數(shù)的時候返回其正數(shù)值

代碼分析

var a = 1;    //  a=1
a+++a;    //  相當于(a++)+a,a經(jīng)過自增運算后為2肯骇,但(a++)為1,故該式為3
typeof a+2;    //  typeof優(yōu)先級高于+祖很,即相當于(typeof a)+2笛丙,即"number2"
 var a = 1;    //  a=1
 var b = 3;    //  b=3
 console.log( a+++b );    //  (a+++b)即((a++)+b),(a++)為1假颇,1+3=4

遍歷數(shù)組[3,4,5]胚鸯,把數(shù)組里的打印數(shù)組每一項的平方

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

遍歷 JSON, 打印里面的值

var obj = {
 name: 'hunger', 
 sex: 'male', 
 age: 28 ;
}

for (var key in obj) {
    console.log(obj[key]);
}

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

邏輯或(||):如果expr1能轉(zhuǎn)換成true則返回expr1,否則返回expr2. 因此,在boolean環(huán)境(在if的條件判斷中)中使用時, 二者操作結(jié)果中只要有一個為true,返回true;二者操作結(jié)果都為false時返回false.

邏輯與(&&):如果expr1 能轉(zhuǎn)換成false則返回expr1,否則返回expr2. 因此, 在Boolean環(huán)境中使用時, 兩個操作結(jié)果都為true時返回true,否則返回false.

var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0   
/* 
(typeof a + b) = "number2" , "number2" || c >0則輸出"number2" 
*/
console.log(val)    //  number2



var d = 5;
var data = d ==5 && console.log('bb')    //d ==5為ture,故data =console.log('bb')
console.log(data)    //console.log(data)=console.log(console.log('bb')),值為 undefined笨鸡;



var data2 = d = 0 || console.log('haha')    
/*
相當于var data2 = d = (0 || console.log('haha'))
即data2 = console.log('haha')
*/
console.log(data2)    //console.log(data2)相當于console.log(console.log('haha'))姜钳,即undefined
 


var x = !!"Hello" + (!"world", !!"from here!!");
/*
!!"Hello"為true
(!"world", !!"from here!!")即((!"world"), (!!"from here!!")),(false,true)→true
x = true + true = 1+1=2
*/
console.log(x)    //    2
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市形耗,隨后出現(xiàn)的幾起案子傲须,更是在濱河造成了極大的恐慌,老刑警劉巖趟脂,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件泰讽,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機已卸,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進店門佛玄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人累澡,你說我怎么就攤上這事梦抢。” “怎么了愧哟?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵奥吩,是天一觀的道長。 經(jīng)常有香客問我蕊梧,道長霞赫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任肥矢,我火速辦了婚禮端衰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘甘改。我一直安慰自己旅东,他們只是感情好,可當我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布十艾。 她就那樣靜靜地躺著抵代,像睡著了一般。 火紅的嫁衣襯著肌膚如雪忘嫉。 梳的紋絲不亂的頭發(fā)上荤牍,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天,我揣著相機與錄音榄融,去河邊找鬼。 笑死救湖,一個胖子當著我的面吹牛愧杯,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鞋既,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼力九,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了邑闺?” 一聲冷哼從身側(cè)響起跌前,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎陡舅,沒想到半個月后抵乓,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年灾炭,在試婚紗的時候發(fā)現(xiàn)自己被綠了茎芋。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡蜈出,死狀恐怖田弥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情铡原,我是刑警寧澤偷厦,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站燕刻,受9級特大地震影響只泼,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜酌儒,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一辜妓、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧忌怎,春花似錦籍滴、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至鸥印,卻和暖如春勋功,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背库说。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工狂鞋, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人潜的。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓骚揍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親啰挪。 傳聞我的和親對象是個殘疾皇子信不,可洞房花燭夜當晚...
    茶點故事閱讀 42,792評論 2 345

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