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

JavaScript 高級(jí)篇之閉包、模擬類(lèi),繼承(五)

 更新時(shí)間:2012年04月07日 02:13:20   作者:  
本篇主要分享我對(duì)閉包的理解及使用閉包完成私有屬性、模擬類(lèi)、繼承等,結(jié)合大量例子,希望大家能快速掌握!首先讓我們先從一些基本的術(shù)語(yǔ)開(kāi)始吧
一、javascript中的閉包
1、我們一起先來(lái)理解什么是函數(shù)的作用域。

2、調(diào)用的對(duì)象

結(jié)合例子:

復(fù)制代碼 代碼如下:

function display(something)
{
function executeDisplay1()
{
document.write("我在幫老板打印:"+something+"<br />");//引用外部函數(shù)的something參數(shù)
}
executeDisplay1();//函數(shù)display引用了內(nèi)部函數(shù)
}
display("sorry");//執(zhí)行完畢后被垃圾收集器回收

3、閉包的形成

例一、

復(fù)制代碼 代碼如下:

var obj = {};//全局的對(duì)象
function buyHouse(price,area)
{
return function(){return "你要付的房款:"+price*area;}; //把內(nèi)部函數(shù)作為返回值
}
obj.people = buyHouse(12000,80); //把內(nèi)部函數(shù)的引用保存到obj對(duì)象的people屬性中。
//這樣就形成了閉包,簡(jiǎn)單的表達(dá):把嵌套函數(shù)的引用保存到全局作用域中,不管是使用它返回的值,還是把它存在對(duì)象的屬性中都可以。
document.write(obj.people()+"<br />");

例二、
復(fù)制代碼 代碼如下:

function add()
{
var number = 0;
return function(){return ++number;};//
}
var num = add();//現(xiàn)在是不是有4引用了吧,第一個(gè)全局創(chuàng)建:訪問(wèn)函數(shù),第二個(gè)有外部函數(shù)(這里指的是Add()引用了匿名函數(shù))
//第三個(gè)是匿名函數(shù)(就是return function.....引用了Add的局部變量),第四個(gè)就全局對(duì)象(var num)了。
//全局對(duì)象的每次調(diào)用的對(duì)象依然保存在函數(shù)體中,所以局部變量的值都會(huì)被維持。
document.write(num());

//等效的方法
num2 = (function(){var number = 0;return function(){return ++number;}})();//匿名函數(shù),直接賦給了全局對(duì)象
document.write(num2());

例三、實(shí)現(xiàn)私有屬性
復(fù)制代碼 代碼如下:

//使用閉包實(shí)現(xiàn)私有屬性
function createProperty(o,propertyname,check)
{
var value;
o["get"+propertyname] = function(){return value;};//將一個(gè)匿名的函數(shù)體返回給對(duì)象的屬性
o["set"+propertyname] = function(v){if(check && !check)//檢查參數(shù)的合法性throw("參數(shù)不對(duì)!");
else value = v; };//將一個(gè)匿名的函數(shù)體返回給對(duì)象的屬性
}
var o = {};
createProperty(o,"Age",function(x){return typeof x == "number";});//后面跟了一個(gè)匿名的函數(shù),執(zhí)行驗(yàn)證的工作,如果不是數(shù)字就返回false
o.setAge(22);//使用對(duì)象的屬性
document.write(o.getAge());

//其實(shí)上面還是將函數(shù)保存到了全局對(duì)象的屬性中。

二、javascript中的類(lèi)
同樣也從一些基本的術(shù)語(yǔ)開(kāi)始吧!
1、原型(prototype)

其實(shí)一個(gè)對(duì)象的原型就是構(gòu)造函數(shù)的prototype的值,所有的函數(shù)都一個(gè)prototype屬性,當(dāng)函數(shù)被創(chuàng)建是就被自動(dòng)創(chuàng)建和初始化,初始化它的值是一個(gè)對(duì)象,這個(gè)對(duì)象自帶一個(gè)屬性就是constructor,它指回到和原型相關(guān)聯(lián)的那個(gè)構(gòu)造函數(shù)。
復(fù)制代碼 代碼如下:

function PeopleHope(money,house)
{
this.money = money;
this.house = house;
}
PeopleHope.prototype.hope = function(){document.write("我想擁有鈔票,房子");};//這就是原型,都會(huì)被構(gòu)造函數(shù)初始化成對(duì)象的屬性。
for(var p in PeopleHope.prototype)
{
document.write("原型出來(lái)了吧! \t " + p + "<br />");//輸出:原型出來(lái)了吧! hope
}

2、模擬類(lèi)

其實(shí)Javascript中的“類(lèi)”就是函數(shù)而已。直接上代碼吧!
復(fù)制代碼 代碼如下:

function PeopleHope(money,house)
{
this.money = money;
this.house = house;
PeopleHope.VERSION = 0.1//類(lèi)的屬性
PeopleHope.createLive = function(){document.write("在黨的領(lǐng)導(dǎo)下,我們的生活很好!");}//類(lèi)方法 必須是類(lèi)直接引用
}

3、類(lèi)的繼承
復(fù)制代碼 代碼如下:

function CreateClass(name,version)
{
this.name = name; //初始化對(duì)象屬性
this.version= version;
CreateClass.AUTHOR = "Frank";//類(lèi)屬性
CreateClass.SellHouse = function(){document.write("我們是房地產(chǎn)龍頭企業(yè)萬(wàn)科");};//類(lèi)的方法
CreateClass.prototype.Company = "vanke";
CreateClass.prototype.HousePrice = function(){document.write("大梅沙山頂豪宅賣(mài)5千萬(wàn)一套,暢銷(xiāo)價(jià)!");};
//原型,其實(shí)到這里大家可能就會(huì)問(wèn)了,這個(gè)原型和類(lèi)方法等有什么區(qū)別呢?
//其實(shí)就是:比如 var o = new CreateClass("中糧地產(chǎn)","一期");CreateClass函數(shù)里面的this就是o了,連起來(lái)就是
//o.name = "中糧地產(chǎn)";o.version = “一期”;吧!
//至于原型其實(shí)在干的事你可以把它理解成一個(gè)”叛徒“在你創(chuàng)建o這個(gè)對(duì)象的時(shí)候,由 原型告訴構(gòu)造函數(shù)一起帶走初始化
//成了對(duì)象o的屬性。
}
function House(name,version,city)
{
CreateClass.apply(this,[name,version]);//繼承構(gòu)造函數(shù)
this.city = city;
House.prototype.housename = "半島花園";
}
House.prototype = new CreateClass("中糧地產(chǎn)","二期");//通過(guò)new獲取CeateClass屬性,包括原型對(duì)象
//打印函數(shù)的prototype屬性
function displayPrototype(c)
{
for(var x in c.prototype)
{
document.write(x+"<br />");
}
}
displayPrototype(House);//輸出:HousePrice Company name version
//刪除不是原型的對(duì)象
delete House.prototype.name;//刪除
delete House.prototype.version;//刪除
displayPrototype(House);//輸出:HousePrice Company
var customers = new House("半島花園","三期","西拔牙");
for(var t in customers)
{
if(typeof customers[t] == "function")//判斷是不是函數(shù)
{
customers[t]();//執(zhí)行
continue;//返回本次,進(jìn)行下一次循環(huán)
}
document.write(t +":\t" + customers[t]+ "<br />");
// 輸出housename: 半島花園 Company: vanke 大梅沙山頂豪宅賣(mài)5千萬(wàn)一套,暢銷(xiāo)價(jià)!name: 半島花園version: 三期 city: 西拔牙
//繼承就實(shí)現(xiàn)了。通過(guò)原型。

小結(jié):本篇就和大家分享到這里吧,本來(lái)還有命名空間要分享,由于學(xué)習(xí)時(shí)間安排的關(guān)系,Javascript語(yǔ)法就給大家分享到這里吧!

下次我將分享我對(duì)javascript客服端的編程及Jquery等高級(jí)應(yīng)用。

相關(guān)文章

最新評(píng)論