這篇文章主要介紹“Javascript中的私有成員是什么意思”,在日常操作中,相信很多人在Javascript中的私有成員是什么意思問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Javascript中的私有成員是什么意思”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
私有Private成員要由構造器生成。這個構造器有三個私有實例變量:param, secret, 和 self。它們被附加到了對象上,但它們無法從外部訪問,同時它們也無法被這個對象的公共方法所訪問。他們只對私有成員可見。
本教程操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。
JavaScript 是世界上最被誤解的語言。很多人認為它缺乏信息隱藏的特性所以對象不能有私有實例變量和方法。但這是一個誤解。JavaScript對象同樣可以擁有私有變量。下面就講解一下:
JavaScript根本上都是關于的對象(Object)的。數組(Array)是對象,函數(Function)是對象,Object就不說了。那什么是對象?對象是名稱-值的配對的集合。名稱是字符串,值可以是字符串、數字、布爾值和對象(包括數組和函數)。對象常常實現為哈希表以快速存取值。
如果一個值是函數,我們可以將它視為方法method。當調用一個對象的方法時,this 變量就會被設為該對象。這個方法就可以通過this變量訪問實例變量。
對象是由構造器constructor產生的,它是初始化對象的函數。構造器提供了其它語言中類提供的特性,包括靜態方法和變量。
對象的成員都是 public 公共成員。任何函數都可以訪問、修改或者刪除這些成員。有兩種主要的途徑給新的對象加入成員:
這個技術一般用來初始化公共實例變量。構造器的this變量是用來向對象添加成員的。
function Container(param) { this.member = param; }
這樣,如果我們構造一個新的對象
var myContainer = new Container('abc');
那么myContainer.member 就會包含'abc'。
這個技巧一般用來添加公共方法。當一個成員被檢索且沒有在對象中發現的時候,那么它就會從對象構造器的 prototype 成員中去獲取它。這個原型機制可用來實現繼承。它也保存內存。要為一個構造器生成的所有對象加入一個方法,將函數加入構造器的prototype 中:
Container.prototype.stamp = function (string) { return this.member + string; }
這樣,我們可以調用這個方法
myContainer.stamp('def')
它會返回'abcdef'.
私有Private成員要由構造器生成。構造器中的普通的var變量和參數都成為私有成員。
function Container(param) { this.member = param; var secret = 3; var self = this; }
這個構造器有三個私有實例變量:param, secret, 和 self。它們被附加到了對象上,但它們無法從外部訪問,同時它們也無法被這個對象的公共方法所訪問。他們只對私有成員可見。私有方法則是構造器內部的函數。
function Container(param) { function dec() { if (secret > 0) { secret -= 1; return true; } else { return false; } } this.member = param; var secret = 3; var self = this; }
私有方法 dec 檢查 secret 實例變量。如果它大于0,就減少secret 的大小并返回 true 。否則它返回 false 。這個可以限制對象使用三次。
按照慣例,我們給出一個私有的 self 參數。這個可以令對象對私有方法可見。這種做法是因為ECMAScript Language Specification中的一個錯誤,這個錯誤令 this 不能正確地對內部函數設置。
私有方法無法被公共方法調用。要令私有方法有用,我們需要引入一種特權方法。
一個特權A privileged 方法可以訪問私有的變量和方法,同時它對公共域可見。也可以刪除或替換一個特權方法,但不能改變它。
特權方法是用 this 在構造器中分配的。
function Container(param) { function dec() { if (secret > 0) { secret -= 1; return true; } else { return false; } } this.member = param; var secret = 3; var self = this; this.service = function () { if (dec()) { return self.member; } else { return null; } }; }
service 就是一個特權方法。前三次調用會返回'abc'。之后 ,它會返回 null。service調用的私有的 dec 方法,而 dec又訪問了私有的 secret變量。service對其它的對象和方法是可見的,但不能直接訪問私有成員。
這種公共、私有和特權成員的模式是可行的原因是由于JavaScript有 closure閉包。這個意味著一個內部的函數總是可以訪問這個函數外部的變量和參數,甚至在外部的函數返回之后。這是這個語言的一個極其強大的特性。目前沒有哪本關于JavaScript編程的書展示了如何發掘這個特性。大多數都沒有提到。
私有和特權成員只能在對象構造的時候生成。公共成員可以在任意時刻添加。
function Constructor(...) { this.membername = value; } Constructor.prototype.membername = value;
function Constructor(...) { var self = this; var membername = value; function membername(...) {...} }
注意,實際上函數語句
function membername(...) {...}
是以下語句的縮寫,兩者相同:
var membername = function membername(...) {...};
function Constructor(...) { this.membername = function (...) {...}; }
到此,關于“Javascript中的私有成員是什么意思”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。