JavaScript 定義了幾種數(shù)據(jù)類型? 哪些是原始類型?哪些是復雜類型?原始類型和復雜類型的區(qū)別是什么?
- ** JavaScript有六種數(shù)據(jù)類型 **
- 1.數(shù)值(number):整數(shù)和小數(shù)(比如1、3.14)
- 2.字符串(string):字符組成的文本(比如“ hello apple ")
- 3.布爾值(boolean):"ture" 和"false"兩個特定值
- 4.undefined:表示未定義或不存在,此處目前沒有任何值
- 5.null:表示空缺,即此處應該有一個值,但目前空缺
- 6.對象(object):各種值組成的集合
- ** 數(shù)值、字符串、布爾值 **為原始類型,他們是最基本的數(shù)據(jù)類型不能再細分了。
- **對象(object) **為復雜類型,復雜類型一般由多個原始類型的數(shù)據(jù)組成,可以看作是存放各種值的容器。
- 對象又可以分為三個子類型
狹義的對象(object)
數(shù)組(array)
函數(shù)(fuction)
正則表達式(regexp) - **undefined、null **為兩個特殊值。
typeof和instanceof的作用和區(qū)別?
- tyoeof運算符可以返回一個值的類型:
原始類型數(shù)值、字符串、布爾值分別返回number、string、boolean
函數(shù)返回function
function f( ) { } typeof f //"fuction"
typeof可以用來檢查一個沒有聲明的變量,而不報錯。
除此以外,其他情況都返回object。 - instance 是用于判斷某個對象是不是構(gòu)造函數(shù)的一個實例
區(qū)分數(shù)組和對象
var o = {}; var a = []; o instanceof Array // false a instanceof Array // true
instanceof返回一個布爾值,該值指示一個對象是否為特定類的一個實例
result = object instanceof class
如果 object 是 class 的一個實例,則 instanceof 運算符返回 true。如果 class 存在于對象的原型鏈中(為 true),則該運算符返回 true。如果 object 不是 class 的實例,或 object 為 null,則該運算符返回 false。
如何判斷一個變量是否是數(shù)字、字符串、布爾、函數(shù)
typeof 123 === 'number'判斷是否是數(shù)字
typeof '123' === 'string'判斷是否為字符串
typeof true ==='boolean'判斷是否為布爾
typeof a ==='function'判斷是否為函數(shù)
NaN是什么? 有什么特別之處?
NaN含義是Not a Number,表示非數(shù)字,NaN和任何值都不想等包括它自己。
如何把非數(shù)值轉(zhuǎn)化為數(shù)值?
Number( )
- 2.
parseLnt( ) parseFloat( )
(1)忽略字符串前面的空白字符,找到第一個非空白字符
(2)如果第一個字符不是-或者數(shù)字返回NaN
(3)如果是繼續(xù)解析,直到非數(shù)值模式為止
(4)0開頭會當做八進制,0x開頭會當做十六進制,但是可以第二個參數(shù)指定基數(shù)
==與===有什么區(qū)別
- ==是值相等,js會在一些情況下進行隱式的類型轉(zhuǎn)換后再進行比較;
- ===是嚴格相等,不會轉(zhuǎn)換數(shù)據(jù)類型;
break與continue有什么區(qū)別
- break 用于強制退出循環(huán)體,執(zhí)行循環(huán)后面的語句;
- continue 用于退出本次循環(huán),執(zhí)行下次循環(huán);
void 0 和 undefined在使用場景上有什么區(qū)別
- void 0 在任何場景下返回值都是underfind;
- underfind 在局部作用域中會被覆寫;
以下代碼的輸出結(jié)果是?為什么?

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

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

Paste_Image.png
遍歷數(shù)組,把數(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+":"+obj[key]}
//輸出 name: 'hunger',
sex: 'male',
age: 28
以下代碼輸出結(jié)果是? 為什么 (選做題目)
var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0;
console.log(val); //結(jié)果為number2。val值為"number2",只要“||”前面為 true,無論“||”后面是true還是false,結(jié)果都返回“||”前面的值。
var d = 5;
var data = d ==5 && console.log('bb');
console.log(data);//結(jié)果為bb,data值為bb,只要“&&”前面是false,無 論“&&”后面是true還是false,結(jié)果都將返“&&”前面的值。
var data2 = d = 0 || console.log('haha');
console.log(data2);//結(jié)果為haha,只要“||”前面為false,無論“||”后面是 true還是false,結(jié)果都返回“||”后面的值。
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x);//結(jié)果為2,空字符串為false,非空則為true,var x = true+(false+true),true為1,1+1=2。