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

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

JavaScript的數(shù)據(jù)類型有七種:數(shù)值(number)、字符串(string)、布爾值(bool)、undefined、null、對象(object)、Symbol(ECMAScript 6 新定義,表示唯一值)
原始類型:數(shù)值(number)、字符串(string)、布爾值(bool)
復(fù)雜類型:對象(object)
對象:狹義的對象、數(shù)組(array)、函數(shù)(function)、正則表達(dá)式(regexp)
特殊值: undefined 未定義或不存在的值,沒有任何值;null 空值,表示有值,值是空的。
區(qū)別:原始類型是最基本的數(shù)據(jù)類型,不能再細(xì)分;復(fù)雜類型是多個(gè)原始類型的值的合成,可以看成一個(gè)存放各種值的容器。

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

typeof的作用是返回一個(gè)值的數(shù)據(jù)類型,返回的結(jié)果是:number、string、boolean、undefined、object、function

instanceof作用是判斷一個(gè)對象是不是由某個(gè)構(gòu)造函數(shù)創(chuàng)建的實(shí)例。返回結(jié)果是true或false

3.如何判斷一個(gè)變量是否是數(shù)字、字符串、布爾、函數(shù)
    var a=123;
    var b="hello";
    var c=false;
    function f() {}
    typeof a   ---number
    typeof b   ---string
    typeof c   ---boolean
    typeof f   ----function
4.NaN是什么?有什么特別之處?

NaN 含義是Not a Number,但它本身是一個(gè)數(shù)值類型,表示非數(shù)字值的特殊值。NaN與其他數(shù)值進(jìn)行比較的結(jié)果總是不相等的,包括它本身在內(nèi)。

    typeof NaN            ---number
    typeof NaN === NaN    ---false
    typeof NaN !== NaN    ---true
    parseInt('abc')      ---NaN
5.如何把非數(shù)值轉(zhuǎn)換成數(shù)值?

有三個(gè)函數(shù)可以把非數(shù)值轉(zhuǎn)換成數(shù)值
Number()函數(shù)、parseInt() 函數(shù)、parseFloat()函數(shù)
注意:
(1)忽略字符串前面的空白字符,找到第一個(gè)非空白字符。
(2)如果第一個(gè)字符不是-或者數(shù)字返回NaN。
(3)繼續(xù)解析,直到是非數(shù)值模式為止
(4)0開頭會當(dāng)成八進(jìn)制,0x開頭會當(dāng)成十六進(jìn)制,但是可以指定第二個(gè)參數(shù)指定基數(shù)。

   Number('13')        //13
   Number('13a')      //NaN
   parseInt('blue');   //NaN
   parseInt('12a')     //12
   parseInt('-23a');   // -23
   parseInt('0xf1');   // 241
   parseInt('101', 2); // 5
   parseFloat('12.3')  //12.3
   parseFloat('1.2a')  //1.2  
6.==與===有什么區(qū)別

==近似相等,比較值是否相等
===絕對相等,比較類型和值都要相等

  undefined == null     //true
  undefined === null    //false
  NaN == NaN       //false
  NaN === NaN      //false
  "1" == true     //true
  "1" === true    //false
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í)行一個(gè)表達(dá)式返回undefined,在某些情況下,undefined是可以被賦值的,比如在函數(shù)中,就不能用undefined來進(jìn)行判斷了,所以就可以用void 0 返回undefined來進(jìn)行判斷

9.以下代碼的輸出結(jié)果是什么?為什么?
  console.log(1+1);       //2
  console.log("2"+"4");   //24
  console.log(2+"4");     //24
  console.log(+"4");      //4
輸出結(jié)果 原因
2 兩個(gè)操作數(shù)都是數(shù)字,做加法運(yùn)算
24 兩個(gè)操作數(shù)都是字符串,字符串拼接
24 把數(shù)字2轉(zhuǎn)換成字符串"2",然后字符串拼接
4 只有一個(gè)字符串參數(shù)的時(shí)候會嘗試將其轉(zhuǎn)化為數(shù)字
10.以下代碼的輸出結(jié)果是什么?
  var a = 1;       //undefined
  a+++a;          // 3   相當(dāng)于(a++)+a,++的優(yōu)先級高于+
  typeof a+2;   //"number2"

輸出結(jié)果:"number2" ,typeof的運(yùn)算優(yōu)先級高于+,先計(jì)算typeof a,typeof a 的返回結(jié)果是"number" ,然后將數(shù)字2轉(zhuǎn)換成字符串"2",最后字符串拼接

11.以下代碼的輸出結(jié)果是什么?為什么
 var a = 1;     //undefined
 var b = 3;    //undefined
 console.log(a+++b);

輸出結(jié)果:4,++的運(yùn)算優(yōu)先級高于+,相當(dāng)于(a++)+b,自增a++是先賦值再加1,所以先執(zhí)行a+b=4,然后執(zhí)行a++=2

12.遍歷數(shù)組,把數(shù)組里的打印數(shù)組每一項(xiàng)的平方
 var arr = [3,4,5]

遍歷數(shù)組用for循環(huán)

 for(var i=0;i<arr.length;i++){
   console.log(arr[i]*arr[i]);
 }
輸出結(jié)果: 9 16 25
13.遍歷JSON,打印里面的值
  var obj = {
   name: 'hunger', 
   sex: 'male', 
   age: 28 
  }

遍歷對象用for-in循環(huán)

for (var key in obj){
  console.log(obj[key]);
}
輸出結(jié)果:  hunger  male  28
14.以下代碼輸出結(jié)果是什么?為什么
  var a = 1, b = 2, c = 3;    //undefined
  var val = typeof a + b || c >0     //undefined
  console.log(val)        //number2 
 
  (1)根據(jù)運(yùn)算符優(yōu)先級先算 typeof a,a=1是數(shù)字,結(jié)果為"number"
  (2)然后計(jì)算+b,b=2,所以結(jié)果為"number2"
  (3)c>0 為true,計(jì)算 "number2" || true
  (4)輸出結(jié)果number2

  var d = 5;    //undefined
  var data = d ==5 && console.log('bb')    //bb 
  console.log(data)     //undefined 

  (1) 根據(jù)優(yōu)先級 var data=(d==5)&&console.log('bb'),先計(jì)算d==5,結(jié)果為true
  (2) console.log('bb'),輸出bb,結(jié)果是undefined
  (3) true && undefined,結(jié)果是undefined
  (4)輸出結(jié)果undefined

  var data2 = d = 0 || console.log('haha')    //haha  
  console.log(data2)     //undefined 

  (1) 根據(jù)優(yōu)先級 console.log('haha'),輸出haha,結(jié)果是undefined
  (2) || 的優(yōu)先級高于=,計(jì)算 0 || undefined,結(jié)果是undefined
  (3)輸出結(jié)果undefined

  var x = !!"Hello" + (!"world", !!"from here!!");  //undefined
  console.log(x)    //2

  (1)根據(jù)優(yōu)先級先計(jì)算小括號里的(!"world", !!"from here!!"),計(jì)算!"world",結(jié)果為false;計(jì)算 !!"from here!!",結(jié)果為true
  (2)計(jì)算(false,true),結(jié)果為true
  (3)true+true,結(jié)果為2,當(dāng)+兩邊都是boolean,會把boolean轉(zhuǎn)換成number,true==1,false==0,true+true結(jié)果為2
  (4)輸出結(jié)果2
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容