本文實例講述了JavaScript私有變量。分享給大家供大家參考,具體如下:
任何在函數中定義的變量,就是私有變量,因為這些變量在函數外部是無法訪問到的。總的來說,私有變量包括函數的參數、局部變量和在函數內部定義的其他函數。
function add(num1, num2){ var sum = num1 + num2; return sum;}上面的例子中的 num1, num2, sum 就是函數的私有變量。
如果在這個函數內部創建一個閉包,那么閉包通過自己的作用域鏈也可以訪問這些變量,利用這一點,就可以創建用于訪問私有變量的公有方法。
有權訪問私有變量和私有函數的公有方法叫做特權方法。
1. 構造函數模式
創建特權方法的方式有兩種,第一種是在構造函數中定義:
function MyObject(){ //私有變量 var privateVariable = 10; //私有函數 function privateFunction(){ return false; } //特權方法 this.publicMethod = function(){ privateVariable++; return privateFunction(); };}這里定義的的特權方法是一個閉包,所以能夠訪問在構造函數中定義的私有變量和私有函數。在創建 MyObject 實例后,只能通過特權方法來訪問定義的私有變量和函數。
利用這種技術,可以隱藏那些不能被外部直接修改的數據:
function Person(name){ this.getName= function () { return name; }; this.setName= function (value) { name=value; }}var person=new Person("deniro");console.log(person.getName());//deniroperson.setName("lily");console.log(person.getName());//lily上面的代碼定義了兩個特權方法,它們都可以在函數外部被調用,因為它們是閉包,所以可以通過作用域訪問 name。name 在 Person 的每一個實例中都不同,因為每次調用構造函數都會重新創建這兩個方法。
在構造函數中創建特權方法的缺點是,必須使用構造函數模式來實現,而這樣做會在每個實例上創建同樣的一組新方法!
2. 靜態私有變量模式
通過在私有作用域中定義私有變量和函數,也可以創建特權方法,基本模式是:
(function(){ //私有變量 var privateVariable = 10; //私有函數 function privateFunction(){ return false; } //構造函數 MyObject = function(){ }; //公有/特權方法 MyObject.prototype.publicMethod = function(){ privateVariable++; return privateFunction(); };})();公有方法在原型上定義,使用的原型模式。另外,我們使用的是函數表達式來定義構造函數,而且沒有用 var,這種在初始化時未經聲明的變量,就會創建一個全局變量。因此,MyObject 就成了一個全局變量,能夠在私有作用域之外被訪問到。但在嚴格模式下給未經聲明的變量賦值會導致錯誤。
新聞熱點
疑難解答
圖片精選