好程式設計師JavaScript教程分享JavaScript中變數和作用域
好程式設計師JavaScript 教程分享 JavaScript 中變數和作用域, JavaScript 的變數與其他語言的變數有很大區別。 JavaScript 變數不是強制型別的,決定了它只是在特定時間用於儲存特定值的一個名字而已。由於不存在定義某個變數必須要儲存何種資料型別值的規則,變數的值及其資料型別可以在指令碼的生命週期內改變。
變數及作用域
1. 基本型別和引用型別的值
常見的兩種不同資料型別的值:基本型別值和引用型別值。基本型別值指的是那些儲存在棧記憶體中的簡單資料段,即這種值完全儲存在記憶體中的一個位置。而引用型別值則是指那些儲存在堆記憶體中的物件,意思是變數中儲存的實際上只是一個指標,這個指標指向記憶體中的另一個位置,該位置儲存物件。
將一個值賦給變數時,解析器必須確定這個值是基本型別值,還是引用型別值。基本型別值有以下幾種:Undefined 、 Null 、 Boolean 、 Number 和 String 。這些型別在記憶體中分別佔有固定大小的空間,他們的值儲存在棧空間,我們透過按值來訪問的。
如果賦值的是引用型別的值,則必須在堆記憶體中為這個值分配空間。由於這種值的大小不固定,因此不能把它們儲存到棧記憶體中。但記憶體地址大小的固定的,因此可以將記憶體地址儲存在棧記憶體中。這樣,當查詢引用型別的變數時,先從棧中讀取記憶體地址,然後再透過地址找到堆中的值。
定義基本型別值和引用型別值的方式幾乎一致的:建立一個變數併為該變數賦值。不過,當這個值儲存到變數中以後,對不同型別值可以執行的操作則大相徑庭。
var test = new Object(); // 建立引用型別
test.name = 'qf'; // 新增一個屬性
alert(test.name); // 輸出
基本型別的值新增屬性,就會出現問題。
var test = 'qf'; // 建立一個基本型別
test.age = 18; // 給基本型別新增屬性
alert(test.age); //undefined
複製變數值
在變數複製方面,基本型別和引用型別也有所不同。基本型別複製的是值本身,而引用型別複製的是地址。
var test = 'qf';
var test2 = test;
檢測型別
要檢測一個變數的型別,我們可以透過typeof 運算子來判別。
var test = 'qf';
alert(typeof (test)); //string
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69913864/viewspace-2702835/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- JavaScript中變數和作用域JavaScript變數
- 好程式設計師web前端教程分享JavaScript Math(算數)物件程式設計師Web前端JavaScript物件
- javascript中的作用域(全域性變數和區域性變數)JavaScript變數
- 好程式設計師web前端教程分享javascript 練習題程式設計師Web前端JavaScript
- 好程式設計師web前端教程分享JavaScript面試題程式設計師Web前端JavaScript面試題
- 好程式設計師web前端教程分享JavaScript簡寫方法程式設計師Web前端JavaScript
- 好程式設計師Web前端教程分享JavaScript開發技巧程式設計師Web前端JavaScript
- 好程式設計師技術教程分享JavaScript運動框架程式設計師JavaScript框架
- 好程式設計師Python教程分享python之變數程式設計師Python變數
- JavaScript之變數及作用域JavaScript變數
- JavaScript 變數的作用域鏈JavaScript變數
- 好程式設計師Java教程分享JavaScript常見面試題一程式設計師JavaScript面試題
- 好程式設計師web前端教程分享前端javascript練習題二程式設計師Web前端JavaScript
- 好程式設計師web前端教程分享前端javascript練習題三程式設計師Web前端JavaScript
- 好程式設計師web前端教程分享JavaScript的執行機制!程式設計師Web前端JavaScript
- 好程式設計師Java教程分享JavaScript常見面試題五程式設計師JavaScript面試題
- 好程式設計師Java教程分享JavaScript常見面試題四程式設計師JavaScript面試題
- 好程式設計師Java教程分享JavaScript常見面試題三程式設計師JavaScript面試題
- 好程式設計師Java教程分享JavaScript常見面試題二程式設計師JavaScript面試題
- 好程式設計師web前端教程分享前端 javascript 練習題二程式設計師Web前端JavaScript
- 好程式設計師分享JavaScript建立物件的方式!程式設計師JavaScript物件
- 好程式設計師分享JavaScript中8個常見的陷阱程式設計師JavaScript
- 好程式設計師web前端教程分享前端javascript練習題之promise程式設計師Web前端JavaScriptPromise
- 現代 JavaScript 的變數作用域JavaScript變數
- 好程式設計師分享JavaScript之-文件物件模型(DOM)程式設計師JavaScript物件模型
- javascript:變數、作用域和記憶體問題JavaScript變數記憶體
- 好程式設計師技術分享淺談JavaScript中的閉包程式設計師JavaScript
- 好程式設計師分享javascript中的常見的相容寫法程式設計師JavaScript
- 好程式設計師前端教程-javascript的物件導向程式設計師前端JavaScript物件
- 好程式設計師web前端教程JavaScript系列之HTTP程式設計師Web前端JavaScriptHTTP
- 好程式設計師web前端分享7個步驟:讓JavaScript變得更好程式設計師Web前端JavaScript
- 好程式設計師web前端教程分享前端javascript練習題Ajax封裝程式設計師Web前端JavaScript封裝
- 好程式設計師web前端培訓分享學習JavaScript程式設計師Web前端JavaScript
- 好程式設計師web前端分享前端 javascript 練習題程式設計師Web前端JavaScript
- 好程式設計師web前端培訓分享JavaScript框架J程式設計師Web前端JavaScript框架
- 好程式設計師技術分享html5和JavaScript的區別程式設計師HTMLJavaScript
- 好程式設計師Java教程分享meta標籤什麼作用程式設計師Java
- 好程式設計師web前端教程分享前端javascript練習題之閉包案例程式設計師Web前端JavaScript