JavaScript 高級(jí)篇之閉包、模擬類(lèi),繼承(五)
1、我們一起先來(lái)理解什么是函數(shù)的作用域。
2、調(diào)用的對(duì)象
結(jié)合例子:
function display(something)
{
function executeDisplay1()
{
document.write("我在幫老板打印:"+something+"<br />");//引用外部函數(shù)的something參數(shù)
}
executeDisplay1();//函數(shù)display引用了內(nèi)部函數(shù)
}
display("sorry");//執(zhí)行完畢后被垃圾收集器回收
3、閉包的形成
例一、
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 />");
例二、
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)私有屬性
//使用閉包實(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ù)。
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ù)而已。直接上代碼吧!
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)的繼承
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)文章
javascript的創(chuàng)建多行字符串的7種方法
多行字符串的作用是用來(lái)提高源代碼的可讀性.尤其是當(dāng)你處理預(yù)定義好的較長(zhǎng)字符串時(shí),把這種字符串分成多行書(shū)寫(xiě)更有助于提高代碼的可讀性和可維護(hù)性.在一些語(yǔ)言中,多行字符串還可以用來(lái)做代碼注釋. 大部分動(dòng)態(tài)腳本語(yǔ)言都支持多行字符串,比如Python, Ruby, PHP. 但Javascript呢?2014-04-04JavaScript更改原始對(duì)象valueOf的方法
這篇文章主要介紹了JavaScript更改原始對(duì)象valueOf的方法,涉及javascript使用自定義valueOf函數(shù)替換掉原始o(jì)bject中valueOf的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03利用Js+Css實(shí)現(xiàn)折紙動(dòng)態(tài)導(dǎo)航效果實(shí)例源碼
這篇文章主要給大家介紹了利用Js+Css實(shí)現(xiàn)折紙動(dòng)態(tài)導(dǎo)航的效果,實(shí)現(xiàn)后的效果非常不錯(cuò),文中給出了簡(jiǎn)單的介紹和完整的實(shí)例代碼,對(duì)大家具有一定的參考價(jià)值,有需要的朋友們下面來(lái)一起看看吧。2017-01-01原生JS發(fā)送異步數(shù)據(jù)請(qǐng)求
這篇文章主要為大家詳細(xì)介紹了原生JS發(fā)送異步數(shù)據(jù)請(qǐng)求的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06JavaScript在IE中“意外地調(diào)用了方法或?qū)傩栽L問(wèn)”
FF是正常的,IE報(bào)“意外地調(diào)用了方法或?qū)傩栽L問(wèn)”。2008-11-11ko knockoutjs動(dòng)態(tài)屬性綁定技巧應(yīng)用
ko的動(dòng)態(tài)屬性是指,ViewModel不確定的屬性,而后期卻需要的屬性,本文將詳細(xì)介紹,需要的朋友參考下2012-11-11JS實(shí)現(xiàn)標(biāo)簽滾動(dòng)切換效果
這篇文章給大家?guī)?lái)的是用JS實(shí)現(xiàn)item標(biāo)簽點(diǎn)擊后滾動(dòng)切換的效果,有興趣的朋友測(cè)試學(xué)習(xí)下吧。2017-12-12