文章出處

1. typeof 運算符
返回一個用來表示表達式的數據類型的字符串。

typeof expression ;

expression 參數是需要查找類型信息的任意表達式。

說明
typeof 是一個一元運算符,放在一個運算數之前。

typeof 運算符把類型信息當作字符串返回。typeof 返回值有六種可能: “number” ,“string”, “boolean”, “object” ,“function”, 和 “undefined.”

(而 ECMAScript 有 5 種原始類型(primitive type),即 Undefined、Null、Boolean、Number 和 String。)

4. instanceof運算符

是一個二元運算符。返回一個 Boolean 值,指出對象是否是特定類的一個實例。

expression  instanceof class

參數

 expression  必選項。任意對象表達式。

 class  必選項。任意已定義的對象類。

說明
如果 object 是 class 的一個實例,則 instanceof 運算符返回 true 。如果 object不是指定類的一個實例,或者 object 是 null ,則返回 false 。

用于判斷一個變量是否某個對象的實例,

如:

var a=new Array();

alert(a instanceof Array);會返回true,

同時alert(a instanceof Object)也會返回true;

這是因為Array是object的子類。

再如:

function test(){};

var a=new test();

alert(a instanceof test)會返回true。

而對于使用typeof的話:

function Person(){}
document.write ("<br>typeof(Person):"+typeof(Person));    //function
var person = new Person();
document.write ("<br>typeof(person):"+typeof(person));    //object

2. 

alert(null == undefined);  //輸出 "true"
盡管這兩個值相等,但它們的含義不同:

undefined 是聲明了變量但未對其初始化時賦予該變量的值 或 未聲明過的變量(只能用于typeof,但作為賦值目標時編譯器會自動將其聲明為全局變量)。

null 則用于表示尚未存在的對象(即對象為空,或對象找不到)。如果函數或方法要返回的是對象,那么找不到該對象時,返回的通常是 null。

3.

我們可以使用 typeof 來獲取一個變量是否存在,如 if(typeof a!="undefined"){alert("ok")},而不要去使用 if(a) 因為如果 a 不存在(未聲明)則會出錯。

對于 Array,Null 等特殊對象使用 typeof 一律返回 object,這正是 typeof 的局限性。如果我們希望獲取一個對象是否是數組,或判斷某個變量是否是某個對象的實例則要選擇使用instanceof

 

判斷一個變量是數組Array類型的方法 http://www.jb51.net/article/41413.htm

 

25個你需要知道的JavaScript面試題:http://www.jb51.net/article/77140.htm

以下主要是摘要,具體詳情還請打開鏈接查看

立即執行函數表達式(Immediately-Invoked Function Expression)

IFE 有兩個比較經典的使用場景,一是類似于在循環中定時輸出數據項,二是類似于 JQuery/Node 的插件和模塊開發。

1
2
3
4
5
for(var i = 0; i < 5; i++) {
 setTimeout(function() {
 console.log(i);
 }, 1000);
}

上面的輸出并不是你以為的0,1,2,3,4,而輸出的全部是5,這時 IIFE 就能有用了:

1
2
3
4
5
6
7
for(var i = 0; i < 5; i++) {
 (function(i) {
 setTimeout(function() {
 console.log(i);
 }, 1000);
 })(i)
}

而在 JQuery/Node 的插件和模塊開發中,為避免變量污染,也是一個大大的 IIFE:

1
2
3
(function($) {
 //代碼
 } )(jQuery);

 

6、下面兩個函數的返回值是一樣的嗎?為什么?

1
2
3
4
5
6
7
8
9
10
11
12
13
14
function foo1()
{
 return {
 bar: "hello"
 };
}
 
function foo2()
{
 return
 {
 bar: "hello"
 };
}

在編程語言中,基本都是使用分號(;)將語句分隔開,這可以增加代碼的可讀性和整潔性。而在JS中,如若語句各占獨立一行,通常可以省略語句間的分號(;),JS 解析器會根據能否正常編譯來決定是否自動填充分號:

1
2
3
var test = 1 +
2
console.log(test); //3

在上述情況下,為了正確解析代碼,就不會自動填充分號了,但是對于 return 、break、continue 等語句,如果后面緊跟換行,解析器一定會自動在后面填充分號(;),所以上面的第二個函數就變成了這樣:

1
2
3
4
5
6
7
function foo2()
{
 return;
 {
 bar: "hello"
 };
}

所以第二個函數是返回 undefined。

 


文章列表


不含病毒。www.avast.com
arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()