js的基礎(chǔ)知識

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

JavaScript語言的每一個(gè)值,都屬于某一種數(shù)據(jù)類型。JavaScript的數(shù)據(jù)類型,共有七種。

數(shù)值(number):整數(shù)和小數(shù)(比如1和3.14)
字符串(string):字符組成的文本(比如"Hello World")
布爾值(boolean):true(真)和false(假)兩個(gè)特定值
undefined:表示“未定義”或不存在,即此處目前沒有任何值
null:表示空缺,即此處應(yīng)該有一個(gè)值,但目前為空
對象(object):各種值組成的集合
symbol:一種特殊的、不可變的數(shù)據(jù)類型,可以作為對象屬性的標(biāo)識符使用。

其中,數(shù)值、字符串和布爾值是原始類型,對象為復(fù)雜類型。
原始類型和復(fù)雜類型的區(qū)別:原始類型是最基本的數(shù)據(jù)類型,不能再細(xì)分;將對象稱為復(fù)雜類型(complex type)的值,因?yàn)橐粋€(gè)對象往往是多個(gè)原始類型的值的合成,可以看作是一個(gè)存放各種值的容器。

undefined和null可以看成兩個(gè)特殊的值。

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

typeof的作用:typeof 是用于返回一個(gè)數(shù)據(jù)其原始的數(shù)據(jù)類型,對于常見的幾大數(shù)據(jù)類型都可以用typeof 數(shù)據(jù)類型的方式進(jìn)行判斷。
typeof是一元運(yùn)算符,返回值為字符串,該字符串用來說明運(yùn)算數(shù)的數(shù)據(jù)類型。
用來獲取運(yùn)算數(shù)的數(shù)據(jù)類型。返回的值有number、boolean、undefined、function、object、string。

console.log(typeof(1));//number
console.log(typeof(true));//boolean
console.log(typeof("abc"));//string
console.log(typeof({}));//object
console.log(typeof(m));//undefined
console.log(typeof(function(){})) //function

instanceof的作用:instance 是用于判斷某個(gè)對象是不是構(gòu)造函數(shù)的一個(gè)實(shí)例,舉例來說就是一個(gè)新聲明的變量是不是調(diào)用了構(gòu)造函數(shù)的內(nèi)置屬性或方法.
instanceof用于判斷某個(gè)變量是否是某個(gè)對象的實(shí)例,返回值為true或false。

區(qū)別:
typeof能夠判斷原始類型和undefined、function,但是不能用來判斷對象類型和null,因?yàn)槎紩祷豲bject。
還可以利用typeof來判斷變量是否存在,不能直接使用if(a),因?yàn)槿绻鸻沒有聲明就會報(bào)錯(cuò)。

if (typeof a === 'undefined') {
    //a不存在
}

instanceof運(yùn)算符時(shí)js語言中原生的用來判斷實(shí)例繼承關(guān)系的操作符。判斷一個(gè)實(shí)例是否屬于某種類型,所以只能判斷對象和函數(shù),不能判斷字符串和數(shù)字。

function Foo(){}
var foo = new Foo();
console.log(foo instanceof Foo); //true

如何判斷一個(gè)變量是否是數(shù)字、字符串、布爾、函數(shù)

typeof即可

NaN是什么? 有什么特別之處?

typeof NaN // 'number'
NAN字面上是 not a number,即表示這個(gè)變量聲明的數(shù)據(jù)類型不是一個(gè)number類型的數(shù)據(jù),它是一個(gè)數(shù)字類型。

特別之處在于任何NaN的值進(jìn)行操作都會返回一個(gè)NaN,其次,NaN與任何值都不相等即NaN === NaN也是false.

如何把非數(shù)值轉(zhuǎn)化為數(shù)值?

三個(gè)方法:

Number('233')
//233
parseInt('233')
//233
parseFloat('233')
//233

==與===有什么區(qū)別

==是近似相等,===是完全相等,==會進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換,===不會,功能上也不同,==是比較數(shù)值等于或否,===是數(shù)據(jù)類型與數(shù)值比較是否相等即全等。

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

break是指當(dāng)條件滿足或被觸發(fā)后直接終止所有循環(huán),即便后面的內(nèi)容并沒有完全執(zhí)行完。

continue是指當(dāng)條件觸發(fā)后跳過當(dāng)前循環(huán)繼續(xù)下一循環(huán),并輸出在次之前和之后的所有結(jié)果。

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

undefined可以在局部作用域中被覆寫,而void運(yùn)算返回都是undefined,因此當(dāng)undefined被改寫的時(shí)候,可以用 void 0代替。

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

console.log(1+1);    //2 1和1都是數(shù)字
console.log("2"+"4");  //24 '2'、'4'都是字符串
console.log(2+"4"); //24 2是數(shù)字,4是‘字符串’
console.log(+"4");//4  只有一個(gè)參數(shù)會返回該參數(shù)的正數(shù)值

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

var a = 1;  
a+++a;  
typeof a+2;

因?yàn)?+的優(yōu)先級比+高,所以該語句可改為(a++)+a;;
a++之后a變?yōu)?,此時(shí)a++的結(jié)果返回依舊是1,然后1+2,該語句變?yōu)?。因?yàn)閠ypeof優(yōu)先級比+高,因此先執(zhí)行typeof a然后返回number,然后'number' + 2,所以這三個(gè)語句最后返回'number2'

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

var a = 1;
var b = 3;
 console.log( a+++b );

++運(yùn)算符的優(yōu)先級別大于+,因此該表達(dá)式可更改為(a++)+b;
a++的結(jié)果依然是1,1+3,所以最后打印的是4

在這里總結(jié)一下a++和++a

a=100;
b=a++;
console.log(a,b)//101 100 a變了,a的結(jié)果沒變

a=100;
b=++a;
console.log(a,b)//101 101 a變了,b的結(jié)果也變了
同異:
相同:a都變了,差異:a的結(jié)果(b)一個(gè)沒變,一個(gè)變了

遍歷數(shù)組,把數(shù)組里的打印數(shù)組每一項(xiàng)的平方

var arr = [3,4,5]

for(var i=0;i<arr.length;i++){
    //以下兩個(gè)皆可打印出正確答案
    //console.log(arr[i]*arr[i]);
    console.log(Math.pow(arr[i],2));

}

遍歷 JSON, 打印里面的值

var obj = {
 name: 'hunger', 
 sex: 'male', 
 age: 28 
}
for(i in  obj){
    console.log(obj[i]);
}

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

var a = 1, b = 2, c = 3;
var val = typeof a + b || c >0
console.log(val) 
//考察的優(yōu)先級,由優(yōu)先級可將該表達(dá)式改為var val = ((typeof a) + b) || (c>0);因此val可以清晰的看出來為var val = 'number2' || true;
因此val為'number2'

var d = 5;
var data = d ==5 && console.log('bb') //'bb'
console.log(data)// undefined
//依然考察的優(yōu)先級,該表達(dá)式可改為var data = (d ==5) && console.log('bb'),此時(shí)就執(zhí)行console.log('bb')打印出'bb'了,同事console.log('bb')返回undefined,undefined被賦值給d和data,因此最后打印data是undefined

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

//只能說是考察||這個(gè)運(yùn)算符了,因?yàn)閨|運(yùn)算符左邊為0,因此取值右邊,然后就打印'haha'了,console.log('haha')返回undefined,然后undefined被賦值給data2,因此最后打印出undefined了
 
var x = !!"Hello" + (!"world", !!"from here!!");
console.log(x)//2

//考察的是取反運(yùn)算符號,!是取反,然后強(qiáng)制將數(shù)值轉(zhuǎn)換為布爾值,!!同樣是將數(shù)值轉(zhuǎn)換為布爾值,但他并沒有取反。還有一個(gè)逗號運(yùn)算符,取,后面那個(gè)值,因此該語句可寫為var x = true + true,則x就被賦值為2了

因?yàn)槊總€(gè)console.log()會返回undefined,就不重復(fù)說明了
最后編輯于
?著作權(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)容

  • JS的基礎(chǔ)應(yīng)用 傳參: 1. (一個(gè)參數(shù)) 聲明:function 名字(參數(shù)){ ...
    小太陽會發(fā)光i閱讀 169評論 0 0
  • 概念 1、CSS和JS在網(wǎng)頁上的放置順序是怎樣的? 將CSS放在head標(biāo)簽中:CSS放在后面會造成白屏或者FOU...
    周花花啊閱讀 511評論 1 1
  • 第一章: JS簡介 從當(dāng)初簡單的語言,變成了現(xiàn)在能夠處理復(fù)雜計(jì)算和交互,擁有閉包、匿名函數(shù), 甚至元編程等...
    LaBaby_閱讀 1,761評論 0 6
  • 現(xiàn)如今,我們身邊的人,極少有人是“貧困”的,大家都對富裕比較感興趣,沒什么人回去討論貧困這個(gè)話題。 其實(shí)“貧困是一...
    東岳不是泰山閱讀 768評論 0 1
  • 如果足夠幸運(yùn),你永遠(yuǎn)不會陷入困境,但最優(yōu)秀的旅行家也難免會犯錯(cuò)。問題根源在于沒有考慮周全就出發(fā)了。下面是弄糟旅途的...
    JackieYu_03d9閱讀 448評論 0 1

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