進階任務(wù)2

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

1.1 JavaScript 定義了六種數(shù)據(jù)類型?

  • 數(shù)值(number):整數(shù)和小數(shù)(比如1和3.14)
  • 字符串(string):字符組成的文本(比如"Hello World")
  • 布爾值(boolean):true(真)和false(假)兩個特定值
  • undefined:表示“未定義”或不存在,即此處目前沒有任何值
  • null:表示空缺,即此處應(yīng)該有一個值,但目前為空
  • 對象(object):各種值組成的集合

1.2 哪些是原始類型?哪些是復(fù)雜類型?

  • 數(shù)值、字符串、布爾值稱為原始類型(primitive type)的值,即它們是最基本的數(shù)據(jù)類型,不能再對齊進行細(xì)分
  • 對象為復(fù)雜類型(complex type)的值,一個對象往往是多個原始類型的值的合成,可以看作是一個存放各種值的容器。
  • undefined和null,一般將它們看成兩個特殊值。

對象又可以細(xì)分為三個子類型:

  • 狹義的對象(object)
  • 數(shù)組(array)
  • 函數(shù)(function)
  • 正則表達(dá)式 (regexp)

1.3 原始類型和復(fù)雜類型的區(qū)別是什么?

1.3.1 特性區(qū)別:

  • 原始值是固定而簡單的值,是存放在棧(stack)中的簡單數(shù)據(jù)段,也就是說,它們的值直接存儲在變量訪問的位置.原始值是表示Javascript中可用的數(shù)據(jù)或信息的最底層形式或最簡單形式。原始類型的值被稱為原始值,是因為它們是不可細(xì)化的。也就是說,數(shù)字是數(shù)字,字符是字符,布爾值則是true或false,null和undefined就是null和undefined。這些值本身很簡單,不能表示由其他值組成的值
  • 復(fù)雜值可以由很多不同類型的javascript對象組成。復(fù)雜對象其在內(nèi)存中的大小是未知的,因為復(fù)雜對象可以包含任何值,而不是一個特定的已知值,

1.3.2 存儲方式區(qū)別

  • 原始值占據(jù)空間固定,是簡單的數(shù)據(jù)段,為了便于提升變量查詢速度,將其存儲在棧(stack)中
  • 由于復(fù)雜值的大小會改變,所以不能將其存放在棧中,否則會降低變量查詢速度,因此其存儲在堆(heap)中,存儲在變量處的值是一個指針,指向存儲對象的內(nèi)存處

1.3.3 訪問方式的區(qū)別

  • 按值訪問
    原始值是作為不可細(xì)化的值進行存儲和操作的,引用它們會轉(zhuǎn)移其值
  • 引用訪問
    復(fù)雜值是通過引用進行存儲和操作的,而不是實際的值。創(chuàng)建一個包含復(fù)雜對象的變量時,其值是內(nèi)存中的一個引用地址。引用一個復(fù)雜對象時,使用它的名稱(即變量或?qū)ο髮傩?通過內(nèi)存中的引用地址獲取該對象值

1.3.4 比較方式的區(qū)別

  • 原始值采用值比較,而復(fù)雜值采用引用比較。復(fù)雜值只有在引用相同的對象(即有相同的地址)時才相等。即使是包含相同對象的兩個變量也彼此不相等,因為它們并不指向同一個對象

1.3.5 動態(tài)屬性的區(qū)別

  • 對于復(fù)雜值,可以為其添加屬性和方法,也可以改變和刪除其屬性和方法;但簡單值不可以添加屬性和方法
    復(fù)雜值支持動態(tài)對象屬性,因為我們可以定義對象,然后創(chuàng)建引用,再更新對象,并且所有指向該對象的變量都會獲得更新。一個新變量指向現(xiàn)有的復(fù)雜對象,并沒有復(fù)制該對象。這就是復(fù)雜值有時被稱為引用值的原因。復(fù)雜值可以根據(jù)需求有任意多個引用,即使對象改變,它們也總是指向同一個對象

1.3.6 包裝類型的區(qū)別

  • 原始值被當(dāng)作構(gòu)造函數(shù)創(chuàng)建的一個對象來使用時,Javascript會將其轉(zhuǎn)換成一個對象,以便可以使用對象的特性和方法,而后拋棄對象性質(zhì),并將它變回到原始值

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

2.1 typeof運算符可以返回一個值的數(shù)據(jù)類型,可能有以下結(jié)果。

  • 原始類型: 數(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開頭會當(dāng)做八進制,0x開頭會當(dāng)做十六進制,但是可以指定第二個參數(shù)指定基數(shù)

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

相等運算符" == "比較兩個值是否相等,嚴(yán)格相等運算符" === "比較它們是否為“同一個值”。如果兩個值不是同一類型,嚴(yán)格相等運算符" === "直接返回false,而相等運算符" == "會將它們轉(zhuǎn)化成同一個類型,再用嚴(yán)格相等運算符進行比較。

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

  • break語句用于跳出代碼塊或循環(huán)。執(zhí)行該代碼塊或循環(huán)的之后的內(nèi)容
  • continue語句用于立即終止本輪循環(huán),返回循環(huán)結(jié)構(gòu)的頭部,開始下一輪循環(huán)的執(zhí)行

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

void運算符的作用是執(zhí)行一個表達(dá)式,然后不返回任何值,或者說返回undefined。
在函數(shù)中,undefined可以被賦值,此時如果需要判斷一個變量為undefined,可以采用 "變量 = void 表達(dá)式"的方式來判斷

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

console.log(1+1);    // 2
console.log("2"+"4");  // 24
console.log(2+"4");  // 24
console.log(+"4");  // 4

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

var a = 1;  //聲明變量 a,且a = 1;
a+++a;      // (a++)+a=1 + 2 = 3
typeof a+2; // (typeof a)+2 = "number"+2 = number2

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

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. 以下代碼輸出結(jié)果是? 為什么 (選做題目)

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
*/
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

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

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