javascript變數、作用域和記憶體問題......

靜逸發表於2015-05-11

1基本型別是指那些儲存在棧記憶體的簡單資料段,引用型別是指那些儲存在堆記憶體中的物件,變數中儲存的實際上只是一個指標。

2javascript中5種基本資料型別Undefined,Null,Boolean,Number和String

3事實上我們不能給基本型別的值新增屬性,儘管在javascript這樣做不會導致任何錯誤。

var name = "Angela";
name.age = 23;
alert(name.age);//undefined;

4ECMAScript中所有函式的引數都是按值傳遞的。

function setName(obj) {
obj.name = "Angela";
}
var person = new Object;
setName(person);
alert(person.name); //Angela
也就是雖然是值傳遞 但是obj事實是是person的一個副本 裡面儲存的是引用堆記憶體的一個指標
所以person和obj指向同一個物件

下面的例子可以更深刻的反應ECMAScript中所有函式的引數都是按值傳遞的

function setName(obj) {
obj.name = "Angela";
obj = new Object;
obj.name = "Yanlong";
}
var person = new Object;
setName(person);
alert(person.name); //Angela

5typeof操作符是確定一個變數是字串、數值、布林值,還是undefined的最佳工具,如果變數的值是一個物件或者是null,則typeof操作符會返回object

6如果使用instanceof操作符檢測基本型別的值,則該操作符始終返回false,因為基本型別不是物件。如果檢測的型別為引用型別的例項,則返回true

7所有全域性變數和函式都是作為window物件的屬性和方法建立的。

8每個函式都有自己的執行環境 ,當程式碼在一個環境中執行時,會建立變數物件的一個作用域鏈

var obj = {};
alert(obj instanceof Object);//true

區別 Jquery物件和Dom物件

在討論之前,先約定好定義變數的風格。

如果獲取的物件是jQuery物件,那麼在變數前加上$,例如:

var $variable = jQuery物件;

如果獲取的是DOM物件,則定義如下:

var variable = DOM物件;

 

jQuery物件不能使用DOM中的方法,但是如果對jQuery物件所提供的方法不熟悉,或者jQuery沒有封裝想要的方法,不得不實用DOM物件的時候,有以下兩種處理方法。jQuery提供了兩種方法將一個jQuery物件轉換成DOm物件,即[index]和get(index).

1、jQuery物件是一個陣列物件,可以通過[index]的方法得到相應的DOM物件。

var $cr = $("#cr"); //jQuery物件
var cr = $cr[0] //DOM物件
alert(cr.checked) //檢測這個checkbox是否選中了

2、通過get(index)方法得到相應的DOM物件。

var $cr = $("#cr");
var cr = $cr.get(0);
alert(cr.checked);

對於一個DOM物件,只需要用$()把DOM物件包裝起來,就可以獲得一個jQuery物件了,方式為$(DOM物件)。

var cr = document.getElementByID("cr"); //DOM物件
var $cr = $(cr);

 

在此總結說明:

jQuery方法裡的get方法事實上是獲得Dom元素($(this).get(0)與$(this)[0])

而jQuery方法裡的eq、first、last等方法都是返回的Jquery物件

DOM物件才能使用DOM中的方法,jQuery物件不可以使用DOM中的方法。jQuery物件提供了一套更加完善的工具用於操作DOM。

相關文章