久久久久久久视色,久久电影免费精品,中文亚洲欧美乱码在线观看,在线免费播放AV片

<center id="vfaef"><input id="vfaef"><table id="vfaef"></table></input></center>

    <p id="vfaef"><kbd id="vfaef"></kbd></p>

    
    
    <pre id="vfaef"><u id="vfaef"></u></pre>

      <thead id="vfaef"><input id="vfaef"></input></thead>

    1. 站長(zhǎng)資訊網(wǎng)
      最全最豐富的資訊網(wǎng)站

      Javascript中什么是私有成員

      私有Private成員要由構(gòu)造器生成。這個(gè)構(gòu)造器有三個(gè)私有實(shí)例變量:param, secret, 和 self。它們被附加到了對(duì)象上,但它們無法從外部訪問,同時(shí)它們也無法被這個(gè)對(duì)象的公共方法所訪問。他們只對(duì)私有成員可見。

      Javascript中什么是私有成員

      本教程操作環(huán)境:windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。

      JavaScript 是世界上最被誤解的語言。很多人認(rèn)為它缺乏信息隱藏的特性所以對(duì)象不能有私有實(shí)例變量和方法。但這是一個(gè)誤解。JavaScript對(duì)象同樣可以擁有私有變量。下面就講解一下:

      對(duì)象

      JavaScript根本上都是關(guān)于的對(duì)象(Object)的。數(shù)組(Array)是對(duì)象,函數(shù)(Function)是對(duì)象,Object就不說了。那什么是對(duì)象?對(duì)象是名稱-值的配對(duì)的集合。名稱是字符串,值可以是字符串、數(shù)字、布爾值和對(duì)象(包括數(shù)組和函數(shù))。對(duì)象常常實(shí)現(xiàn)為哈希表以快速存取值。

      如果一個(gè)值是函數(shù),我們可以將它視為方法method。當(dāng)調(diào)用一個(gè)對(duì)象的方法時(shí),this 變量就會(huì)被設(shè)為該對(duì)象。這個(gè)方法就可以通過this變量訪問實(shí)例變量。

      對(duì)象是由構(gòu)造器constructor產(chǎn)生的,它是初始化對(duì)象的函數(shù)。構(gòu)造器提供了其它語言中類提供的特性,包括靜態(tài)方法和變量。

      公共成員

      對(duì)象的成員都是 public 公共成員。任何函數(shù)都可以訪問、修改或者刪除這些成員。有兩種主要的途徑給新的對(duì)象加入成員:

      構(gòu)造器中

      這個(gè)技術(shù)一般用來初始化公共實(shí)例變量。構(gòu)造器的this變量是用來向?qū)ο筇砑映蓡T的。

      function Container(param) {         this.member = param; }

      這樣,如果我們構(gòu)造一個(gè)新的對(duì)象

      var myContainer = new Container('abc');

      那么myContainer.member 就會(huì)包含'abc'。

      原型中

      這個(gè)技巧一般用來添加公共方法。當(dāng)一個(gè)成員被檢索且沒有在對(duì)象中發(fā)現(xiàn)的時(shí)候,那么它就會(huì)從對(duì)象構(gòu)造器的 prototype 成員中去獲取它。這個(gè)原型機(jī)制可用來實(shí)現(xiàn)繼承。它也保存內(nèi)存。要為一個(gè)構(gòu)造器生成的所有對(duì)象加入一個(gè)方法,將函數(shù)加入構(gòu)造器的prototype 中:

      Container.prototype.stamp = function (string) { 	return this.member + string; }

      這樣,我們可以調(diào)用這個(gè)方法

      myContainer.stamp('def')

      它會(huì)返回'abcdef'.

      私有成員

      私有Private成員要由構(gòu)造器生成。構(gòu)造器中的普通的var變量和參數(shù)都成為私有成員。

      function Container(param) { 	this.member = param;     var secret = 3;     var self = this;     }

      這個(gè)構(gòu)造器有三個(gè)私有實(shí)例變量:param, secret, 和 self。它們被附加到了對(duì)象上,但它們無法從外部訪問,同時(shí)它們也無法被這個(gè)對(duì)象的公共方法所訪問。他們只對(duì)私有成員可見。私有方法則是構(gòu)造器內(nèi)部的函數(shù)。

      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 實(shí)例變量。如果它大于0,就減少secret 的大小并返回 true 。否則它返回 false 。這個(gè)可以限制對(duì)象使用三次。

      按照慣例,我們給出一個(gè)私有的 self 參數(shù)。這個(gè)可以令對(duì)象對(duì)私有方法可見。這種做法是因?yàn)镋CMAScript Language Specification中的一個(gè)錯(cuò)誤,這個(gè)錯(cuò)誤令 this 不能正確地對(duì)內(nèi)部函數(shù)設(shè)置。

      私有方法無法被公共方法調(diào)用。要令私有方法有用,我們需要引入一種特權(quán)方法。

      特權(quán)成員

      一個(gè)特權(quán)A privileged 方法可以訪問私有的變量和方法,同時(shí)它對(duì)公共域可見。也可以刪除或替換一個(gè)特權(quán)方法,但不能改變它。

      特權(quán)方法是用 this 在構(gòu)造器中分配的。

      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 就是一個(gè)特權(quán)方法。前三次調(diào)用會(huì)返回'abc'。之后 ,它會(huì)返回 null。service調(diào)用的私有的 dec 方法,而 dec又訪問了私有的 secret變量。service對(duì)其它的對(duì)象和方法是可見的,但不能直接訪問私有成員。

      閉包

      這種公共、私有和特權(quán)成員的模式是可行的原因是由于JavaScript有 closure閉包。這個(gè)意味著一個(gè)內(nèi)部的函數(shù)總是可以訪問這個(gè)函數(shù)外部的變量和參數(shù),甚至在外部的函數(shù)返回之后。這是這個(gè)語言的一個(gè)極其強(qiáng)大的特性。目前沒有哪本關(guān)于JavaScript編程的書展示了如何發(fā)掘這個(gè)特性。大多數(shù)都沒有提到。

      私有和特權(quán)成員只能在對(duì)象構(gòu)造的時(shí)候生成。公共成員可以在任意時(shí)刻添加。

      模式

      公共(Public)

      function Constructor(...) { 	this.membername = value; } Constructor.prototype.membername = value;

      私有(Private)

      function Constructor(...) {   	var self =  this; 	var membername =  value;   	function  membername(...)  {...} }

      注意,實(shí)際上函數(shù)語句

      function  membername(...)  {...}

      是以下語句的縮寫,兩者相同:

      var  membername = function  membername(...)  {...};

      特權(quán)(Privileged)

      function Constructor(...) {   	this.membername =  function (...)  {...}; }

      【推薦學(xué)習(xí):javascript高級(jí)教程】

      贊(0)
      分享到: 更多 (0)
      網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)