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

javascript Object與Function使用

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

JavaScript的對象體系結構

其實在JavaScript語言中,整個核心的體系結構都圍繞著兩個構造函數Object和Function來構建的。我將引用來自mollypages.org的一張JavaScript對象體系結構圖來說明。

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

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


JavaScript中的原型鏈(prototype chain)機制
這里簡單概括一下,因為這個話題需要很大篇幅去討論,本文只是引用了這個概念,重點并非詳細討論該機制。
JavaScript中的原型(prototype)是和函數(function)緊密相連的,因為每個函數默認都會有一個屬性叫prototype, 每一個通過函數和new操作符生成的對象都具有一個屬性__proto__, 這個屬性保存了創建它的構造函數的prototype屬性的引用。這個__proto__對象就是實現原型鏈的核心對象。JavaScript是一門面向對象的編程語言,它的繼承特性其實就是通過原型鏈機制來實現的。同時,instanceof運算符也需要在原型鏈的支持。我們舉例說明:

代碼
復制代碼 代碼如下:
// 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



從上面的代碼來分析,我們不難得出這樣一個結論:任何對象的原型鏈最后都能追溯到Object.prototype. 這也就是我們為什么說JavaScript中所有的對象都繼承自Object的原因了。

為何Object instanceof Function和Function instanceof Object都返回true?
Object, Function, Array等等這些都被稱作是構造“函數”,他們都是函數。而所有的函數都是構造函數Function的實例。從原型鏈機制的的角度來說,那就是說所有的函數都能通過原型鏈找到創建他們的Function構造函數的構造原型Function.protorype對象,所以:

alert(Object instanceof Function);// return true
與此同時,又因為Function.prototype是一個對象,所以他的構造函數是Object. 從原型鏈機制的的角度來說,那就是說所有的函數都能通過原型鏈找到創建他們的Object構造函數的構造原型Object.prototype對象,所以:

alert(Function instanceof Object);// return true
有趣的是根據我們通過原型鏈機制對instanceof進行的分析,我們不難得出一個結論:Function instanceof Function 依然返回true, 原理是一樣的
1. Function是構造函數,所以它是函數對象
2. 函數對象都是由Function構造函數創建而來的,原型鏈機制解釋為:函數對象的原型鏈中存在Function.prototype
3. instanceof查找原型鏈中的每一個節點,如果Function.prototype的構造函數Function的原型鏈中被查到,返回true
因此下面代碼依然返回true

alert(Function instanceof Function);// still true

結論
1. 在JavaScript語言中,一切的一切都是對象,它們全部繼承自Object. 或者說所有對象的原型鏈的根節點都是Object.prototype
2. 理解原型鏈機制在JavaScript中式如何工作的是非常重要的。掌握了它,不管一個對象多么復雜,你總能夠輕而易舉地將它攻破。

JavaScript技術javascript Object與Function使用,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 做暧暧免费30秒体验 | 调教椅上的调教SM总裁被调教 | 亚洲日产2020乱码草莓毕 | 国模啪啪久久久久久久 | 午夜宅宅伦电影网 | 年轻的母亲4线在线观看完整 | 国产亚洲精品在浅麻豆 | 国产精品亚洲一区二区三区久久 | 免费乱理伦片在线观看八戒 | 多人乱肉高hnp | 孕妇泬出白浆18P | 日日夜夜狠狠干 | 狠狠撸亚洲视频 | 啪啪激情婷婷久久婷婷色五月 | 欧美丰满熟妇BBB久久久 | 国偷自产AV一区二区三区健身房 | 亚洲中文字幕永久在线 | AV无码九九久久 | 男女性杂交内射妇女BBWXZ | 吃寂寞寡妇的奶 | 亚洲伊人精品 | 亚洲香蕉网久久综合影院 | 影音先锋av男人资源 | 夜夜澡人人爽人人喊_欧美 夜夜骑夜夜欢 | 免费一级片网站 | 久久se视频精品视频在线 | 亚洲精品乱码久久久久久直播 | 玩弄朋友娇妻呻吟交换电影 | 毛片基地看看成人免费 | 久久99国产亚洲高清观着 | 寂寞骚妇女被后入式抽插 | 菠萝菠萝蜜视频在线看1 | 久久精品WWW人人爽人人 | 男人的天堂色 | 麻豆免费观看高清完整视频在线 | 美目盼兮amy198281 | 亚洲AV无码专区国产精品99 | 暖暖直播免费观看韩国 | 久久精品午夜一区二区福利 | 日韩 国产 欧美视频二区 | 怪物高h粗暴无尽 |