亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺說js變量

 更新時間:2011年05月25日 21:49:51   作者:  
JavaScript 是弱類型, 變量可存儲任意類型, 并且運行期間類型可變
復制代碼 代碼如下:

/*
1, 變量類型:
JavaScript 是弱類型, 變量可存儲任意類型, 并且運行期間類型可變;
-> 變量可進行類型轉換;
*/


/*
2, 變量聲明:
*/
var i;
var index;
var i, index;
var i = 0, index = 2;
/*
變量聲明, 無初始值時, 值為 undefined;
并且 var 聲明的變量, 不能使用 delete 操作符刪除;
重復聲明為產生覆蓋, 不會造成錯誤;
遺漏聲明, 則會把變量隱式聲明此變量, 并做為全局變量; (下節(jié)介紹)
*/


/*
3, 變量作用域:
以函數(shù)劃分: 函數(shù)內部聲明的變量, 只能運行的函數(shù)內部, 即局部變量; (閉包仍可引用);
內部變量比全局變量優(yōu)先級別高; ex:
*/
var g = 'global';
function check() {
var g = 'local';
console.log(g); // local
}
check();
/* 變量盡可能都使用 var 聲明 */
/* 沒有塊級作用域 */
if (false) {
var test = 2;
function t() {
console.log('t function');
}
}
t(); // t function;
console.log(test); // undefined;
/*
例外:
firefox 會報錯;
t is not defined;
test 值為 undefined;(末聲明和賦值的變量都是 undefined)
*/

/* 變量聲明會提前掛起 */
function f() {
console.log(test); // undefined
var test = 'test';
console.log(test); // 'test'
}
// 轉化為
function f() {
var test;
console.log(test); // 變量僅聲明, 則初始化為 undefined
test = 'test';
console.log(test); // 變量已賦值, 'test'
}
/* 未定義變量和未賦值變量 */
console.log(t); // 直接使用變量 t;
// 注: 直接給變量賦值時, 會隱式的把變量做為全局對待;
var t; // 未賦值變量, undefined;

/*
4, 基本類型和引用類型:
Number/boolean/null/undefined/ 基本類型;
Array/Object/Function 引用類型
第五版, 63頁:
無論將字符串看作是行為與基本類型相似的不可變引用類型,
還是將它看作使用引用類型的內部功能實現(xiàn)的基本類型, 結果都是一樣的;
即: String 類型表現(xiàn)為 基本類型;
下面實例說明基本類型和引用類型差別:
*/
var a = 3.14;
var b = a;
a = 4;
console.log(a, b); // 4, 3.14;

var a = [1, 2, 3];
var b = a;
a[0] = 99;
console.log(a, b); // 相同; [99, 2, 3];
// 數(shù)組是引用類型, 變量a和b 指向同一塊內存地址;
// 變量保存基本類型的實際值, 而保存引用類型的引用(類指針);

/*
5, 垃圾收集
引用類型是沒有固定大小的, 比如: Array, 隨時可以修改 length;
變量并不能直接保存引用的值, 而是被存儲在某個位置, 變量保存的只是對此位置的引用.
所以, JavaScript 會動態(tài)分配內存來存儲實體;
最終要釋放這些內存以便再用, 否則會消耗所有可用內存導致系統(tǒng)崩潰;
JavaScript 不要求手動釋放內存; 它使用一種稱為垃圾收集方法[方法不可見];
它會把對不再使用的對象所占用的內存釋放;
*/
var s = 'hello';
var u = s.toUpperCase();
s = u; // 不能再獲取到 'hello' 值;
// 環(huán)境中不再有 'hello' 引用[沒有變量指向它]
// (是否進行回收, 是通過是否存在賦值決定的)
/*
6, 作為屬性的變量
全局對象
window, this, Math;
瀏覽器中的:navigator, screen;
局部變量:調用對象
調用對象
全局變量是特殊的全局對象的屬性, 那么局部變量被稱為調用對象(call object)的屬性;
函數(shù)的參數(shù)和局部變量作為調用對象的屬性而存儲;
(使用獨立對象存儲局部變量使 JavaScript 可防止局部變量覆蓋同名全局變量的值)
JavaScript 的執(zhí)行環(huán)境
JavaScript 解釋器執(zhí)行一個函數(shù)時, 會為函數(shù)創(chuàng)建一個執(zhí)行環(huán)境(execution context);
一個執(zhí)行環(huán)境就是所有 JavaScript 代碼段執(zhí)行時所在的環(huán)境.
運行不屬性任何函數(shù)的 JavaScript 代碼的環(huán)境使用的就是全局對象.
所有 JavaScript 函數(shù)都運行在 自己獨有的執(zhí)行環(huán)境中, 并且有自己的調用對象, 在調用對象中定義了局部變量.
JavaScript 解釋器可在不同的全局執(zhí)行環(huán)境中運行腳本, 并且這些環(huán)境不脫節(jié), 彼此可引用;
(window-iframe);
深入理解變量作用域
每個 JavaScript 執(zhí)行環(huán)境都有一個和它關聯(lián)在一起的作用域鏈(scope chain);
作用域鏈是一個對象列表或對象鏈;
當 JavaScript 代碼需要查詢變量 X 的值時, 它就開始查看此鏈上的第一個對象;
如果對象存在一個名為 x 的屬性, 那么就采用那個屬性的值.
如果沒有, JavaScript 會繼續(xù)查詢鏈中的第二個對象.
如果還沒有找到, 繼續(xù)查詢下一個對象. 以此類推...
補充:
f() 作用域 -> 閉包作用域 -> var 變量所在作用域
-> Object 的原型作用域 -> Object 類屬性作用域
-> 頂層作用域(window);
*/

相關文章

最新評論