天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript Object與Function使用

如今的JavaScript再也不是以前被當(dāng)做玩具的在網(wǎng)頁(yè)上運(yùn)行的花哨的腳本了。JavaScript已經(jīng)逐漸標(biāo)準(zhǔn)化,作為一門(mén)真正的編程語(yǔ)言廣泛地應(yīng)用在Web開(kāi)發(fā)上。因此,越來(lái)越多的人開(kāi)始重新認(rèn)識(shí)這門(mén)腳本語(yǔ)言,并在不斷地探索關(guān)于JavaScript核心思想和實(shí)現(xiàn)原理,過(guò)程中遇到了一些非常混淆的問(wèn)題。本文著重解釋一個(gè)比較常見(jiàn)但是非常容易使開(kāi)發(fā)人員或者是初學(xué)JavaScript的人非常混淆的問(wèn)題,那就是兩個(gè)核心構(gòu)造函數(shù)Object和Function,他們之間到底有什么關(guān)系?為何instanceof運(yùn)算符的返回結(jié)果會(huì)讓你感到混淆?本文將為你一一道來(lái)。不過(guò)在這之前,我們需要先了解一些JavaScript中的概念和基本的運(yùn)行機(jī)制。

JavaScript的對(duì)象體系結(jié)構(gòu)

其實(shí)在JavaScript語(yǔ)言中,整個(gè)核心的體系結(jié)構(gòu)都圍繞著兩個(gè)構(gòu)造函數(shù)Object和Function來(lái)構(gòu)建的。我將引用來(lái)自mollypages.org的一張JavaScript對(duì)象體系結(jié)構(gòu)圖來(lái)說(shuō)明。

instanceof 運(yùn)算符
instanceof是一個(gè)二元運(yùn)算符,如:A instanceof B. 其中,A必須是一個(gè)合法的JavaScript對(duì)象,B必須是一個(gè)合法的JavaScript函數(shù) (function). 判斷過(guò)程如下:
如果函數(shù)B在對(duì)象A的原型鏈 (prototype chain) 中被發(fā)現(xiàn),那么instanceof操作符將返回true,否則返回false.
例如下面的代碼會(huì)返回true.

// return true if specified function is found// in the object's prototype chain as a constructor.alert({} instanceof Object);


JavaScript中的原型鏈(prototype chain)機(jī)制
這里簡(jiǎn)單概括一下,因?yàn)檫@個(gè)話題需要很大篇幅去討論,本文只是引用了這個(gè)概念,重點(diǎn)并非詳細(xì)討論該機(jī)制。
JavaScript中的原型(prototype)是和函數(shù)(function)緊密相連的,因?yàn)槊總€(gè)函數(shù)默認(rèn)都會(huì)有一個(gè)屬性叫prototype, 每一個(gè)通過(guò)函數(shù)和new操作符生成的對(duì)象都具有一個(gè)屬性__proto__, 這個(gè)屬性保存了創(chuàng)建它的構(gòu)造函數(shù)的prototype屬性的引用。這個(gè)__proto__對(duì)象就是實(shí)現(xiàn)原型鏈的核心對(duì)象。JavaScript是一門(mén)面向?qū)ο蟮木幊陶Z(yǔ)言,它的繼承特性其實(shí)就是通過(guò)原型鏈機(jī)制來(lái)實(shí)現(xiàn)的。同時(shí),instanceof運(yùn)算符也需要在原型鏈的支持。我們舉例說(shuō)明:

代碼
復(fù)制代碼 代碼如下:
// create a custom constructor Foo
function Foo() {
}
// create an insatnce of Foo
var foo = new Foo();

// foo is an instance of Foo
alert(foo instanceof Foo);// true
// foo is also an instance of Object because
// Foo.prototype is an instance of Object.
// the interpreter will find the constructor
// through the prototype chain.
alert(foo instanceof Object);// true

// Prototype chain of the object foo
//
// __proto__ __proto__ __proto__
// foo -----------> Foo.prototype -----------> Object.prototype -----------> null

// But foo is not an instance of Function, because
// we could not find Function.prototype in foo's
// prototype chain.
alert(foo instanceof Function);// false

// However, its constructor Foo is an instance of
// Function.
alert(Foo instanceof Function);// true
// it's also an instance of Object
alert(Foo instanceof Object);// true

// Prototype chain of the constructor Foo
//
// __proto__ __proto__ __proto__
// Foo -----------> Function.prototype -----------> Object.prototype -----------> null



從上面的代碼來(lái)分析,我們不難得出這樣一個(gè)結(jié)論:任何對(duì)象的原型鏈最后都能追溯到Object.prototype. 這也就是我們?yōu)槭裁凑f(shuō)JavaScript中所有的對(duì)象都繼承自O(shè)bject的原因了。

為何Object instanceof Function和Function instanceof Object都返回true?
Object, Function, Array等等這些都被稱(chēng)作是構(gòu)造“函數(shù)”,他們都是函數(shù)。而所有的函數(shù)都是構(gòu)造函數(shù)Function的實(shí)例。從原型鏈機(jī)制的的角度來(lái)說(shuō),那就是說(shuō)所有的函數(shù)都能通過(guò)原型鏈找到創(chuàng)建他們的Function構(gòu)造函數(shù)的構(gòu)造原型Function.protorype對(duì)象,所以:

alert(Object instanceof Function);// return true
與此同時(shí),又因?yàn)镕unction.prototype是一個(gè)對(duì)象,所以他的構(gòu)造函數(shù)是Object. 從原型鏈機(jī)制的的角度來(lái)說(shuō),那就是說(shuō)所有的函數(shù)都能通過(guò)原型鏈找到創(chuàng)建他們的Object構(gòu)造函數(shù)的構(gòu)造原型Object.prototype對(duì)象,所以:

alert(Function instanceof Object);// return true
有趣的是根據(jù)我們通過(guò)原型鏈機(jī)制對(duì)instanceof進(jìn)行的分析,我們不難得出一個(gè)結(jié)論:Function instanceof Function 依然返回true, 原理是一樣的
1. Function是構(gòu)造函數(shù),所以它是函數(shù)對(duì)象
2. 函數(shù)對(duì)象都是由Function構(gòu)造函數(shù)創(chuàng)建而來(lái)的,原型鏈機(jī)制解釋為:函數(shù)對(duì)象的原型鏈中存在Function.prototype
3. instanceof查找原型鏈中的每一個(gè)節(jié)點(diǎn),如果Function.prototype的構(gòu)造函數(shù)Function的原型鏈中被查到,返回true
因此下面代碼依然返回true

alert(Function instanceof Function);// still true

結(jié)論
1. 在JavaScript語(yǔ)言中,一切的一切都是對(duì)象,它們?nèi)坷^承自O(shè)bject. 或者說(shuō)所有對(duì)象的原型鏈的根節(jié)點(diǎn)都是Object.prototype
2. 理解原型鏈機(jī)制在JavaScript中式如何工作的是非常重要的。掌握了它,不管一個(gè)對(duì)象多么復(fù)雜,你總能夠輕而易舉地將它攻破。

JavaScript技術(shù)javascript Object與Function使用,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲精品乱码久久久久久中文字幕 | 午夜视频在线网站 | 乱精品一区字幕二区 | 亚洲 制服 欧美 中文字幕 | 中文字幕免费视频精品一 | 九九热伊人 | 东北疯狂xxxxbbbb中国 | 国产嫩草在线观看 | 国产一区二区在线观看免费 | 国产精品A久久777777 | 久草免费视频在线观看 | 人禽l交视频在线播放 视频 | 国产在线亚洲精品观看不卡 | 某上海少妇3P黑人完整版BD | 早乙女由依在线观看 | 无限资源在线看影院免费观看 | 免费国产在线观看 | 婷婷久久无码欧美人妻 | 欧美一区二区三区播放 | 六六影院午夜伦理 | 特黄特黄aaaa级毛片免费看 | 欧美在线看费视频在线 | 黄色三级在线观看 | 回复术士勇者免费观看全集 | 99视频在线观看免费视频 | 久久久97人妻无码精品蜜桃 | 澳大利亚剧满足在线观看 | 国产激情视频在线 | 囚禁固定在调教椅上扩张H 秋霞最新高清无码鲁丝片 秋霞在线看片无码免费 | 秋霞电影院午夜伦高清 | 青青操久久 | 中文字幕在线视频网站 | 60老妇性xxxxhd | 18禁无遮遮挡羞漫画免费阅读 | 李丽莎与土豪50分钟在线观看 | 性虎成人网| 69久久国产精品热88人妻 | 超碰在线97av视频免费 | 亚洲欧洲日本无在线码播放 | 无码人妻视频又大又粗欧美 | 伊人久久精品AV一区二区 |