• <sub id="h4knl"><ol id="h4knl"></ol></sub>
    <sup id="h4knl"></sup>
      <sub id="h4knl"></sub>

      <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
      1. <strong id="h4knl"></strong>

      2. JavaScript精煉之構(gòu)造函數(shù)

        時(shí)間:2024-07-07 01:58:21 JavaScript 我要投稿
        • 相關(guān)推薦

        JavaScript精煉之構(gòu)造函數(shù)

          除了創(chuàng)建對象,構(gòu)造函數(shù)(constructor) 還做了另一件有用的事情—自動為創(chuàng)建的新對象設(shè)置了原型對象(prototype object) 。原型對象存放于 ConstructorFunction.prototype 屬性中。

          例如,我們重寫之前例子,使用構(gòu)造函數(shù)創(chuàng)建對象“b”和“c”,那么對象”a”則扮演了“Foo.prototype”這個角色:

          // 構(gòu)造函數(shù)function Foo(y) { // 構(gòu)造函數(shù)將會以特定模式創(chuàng)建對象:被創(chuàng)建的對象都會有"y"屬性 this.y = y;}// "Foo.prototype"存放了新建對象的原型引用// 所以我們可以將之用于定義繼承和共享屬性或方法// 所以,和上例一樣,我們有了如下代碼:// 繼承屬性"x"Foo.prototype.x = ;// 繼承方法"calculate"Foo.prototype.calculate = function (z) { return this.x + this.y + z;};// 使用foo模式創(chuàng)建 "b" and "c"var b = new Foo();var c = new Foo();// 調(diào)用繼承的方法b.calculate(); // c.calculate(); // // 讓我們看看是否使用了預(yù)期的屬性console.log( b.__proto__ === Foo.prototype, // true c.__proto__ === Foo.prototype, // true // "Foo.prototype"自動創(chuàng)建了一個特殊的屬性"constructor" // 指向a的構(gòu)造函數(shù)本身 // 實(shí)例"b"和"c"可以通過授權(quán)找到它并用以檢測自己的構(gòu)造函數(shù) b.constructor === Foo, // true c.constructor === Foo, // true Foo.prototype.constructor === Foo // true b.calculate === b.__proto__.calculate, // true b.__proto__.calculate === Foo.prototype.calculate // true);

          上述代碼可表示為如下的關(guān)系:

          構(gòu)造函數(shù)與對象之間的關(guān)系

          上述圖示可以看出,每一個object都有一個prototype. 構(gòu)造函數(shù)Foo也擁有自己的__proto__, 也就是Function.prototype, 而Function.prototype的__proto__指向了Object.prototype. 重申一遍,F(xiàn)oo.prototype只是一個顯式的屬性,也就是b和c的__proto__屬性。

          這個問題完整和詳細(xì)的解釋有兩個部分:

          面向?qū)ο缶幊?一般理論(OOP. The general theory),描述了不同的面向?qū)ο蟮姆妒脚c風(fēng)格(OOP paradigms and stylistics),以及與ECMAScript的比較。

          面向?qū)ο缶幊?ECMAScript實(shí)現(xiàn)(OOP. ECMAScript implementation), 專門講述了ECMAScript中的面向?qū)ο缶幊獭?/p>

          現(xiàn)在,我們已經(jīng)了解了基本的object原理,那么我們接下去來看看ECMAScript里面的程序執(zhí)行環(huán)境[runtime program execution]. 這就是通常稱為的“執(zhí)行上下文堆棧”[execution context stack]。每一個元素都可以抽象的理解為object。你也許發(fā)現(xiàn)了,沒錯,在ECMAScript中,幾乎處處都能看到object的身影。

          下面給大家介紹JavaScript constructor 屬性詳解

          對象的constructor屬性用于返回創(chuàng)建該對象的函數(shù),也就是我們常說的構(gòu)造函數(shù)。

          在JavaScript中,每個具有原型的對象都會自動獲得constructor屬性。除了arguments、Enumerator、Error、Global、Math、RegExp、Regular Expression等一些特殊對象之外,其他所有的JavaScript內(nèi)置對象都具備constructor屬性。例如:Array、Boolean、Date、Function、Number、Object、String等。所有主流瀏覽器均支持該屬性。

          語法

          object.constructor

          返回值

          對象的constructor屬性返回創(chuàng)建該對象的函數(shù)的引用。

          示例&說明

          以下代碼中的[native code],表示這是JavaScript的底層內(nèi)部代碼實(shí)現(xiàn),無法顯示代碼細(xì)節(jié)。

          // 字符串:String()var str = "張三";document.writeln(str.constructor); // function String() { [native code] }document.writeln(str.constructor === String); // true// 數(shù)組:Array()var arr = [1, 2, 3];document.writeln(arr.constructor); // function Array() { [native code] }document.writeln(arr.constructor === Array); // true// 數(shù)字:Number()var num = 5;document.writeln(num.constructor); // function Number() { [native code] }document.writeln(num.constructor === Number); // true// 自定義對象:Person()function Person(){ this.name = "CodePlayer";}var p = new Person();document.writeln(p.constructor); // function Person(){ this.name = "CodePlayer"; }document.writeln(p.constructor === Person); // true// JSON對象:Object()var o = { "name" : "張三"};document.writeln(o.constructor); // function Object() { [native code] }document.writeln(o.constructor === Object); // true// 自定義函數(shù):Function()function foo(){ alert("CodePlayer");}document.writeln(foo.constructor); // function Function() { [native code] }document.writeln(foo.constructor === Function); // true// 函數(shù)的原型:bar()function bar(){ alert("CodePlayer");}document.writeln(bar.prototype.constructor); // function bar(){ alert("CodePlayer"); }document.writeln(bar.prototype.constructor === bar); // true

        【JavaScript精煉之構(gòu)造函數(shù)】相關(guān)文章:

        淺析jQuery 遍歷函數(shù)javascript08-06

        Javascript函數(shù)的定義和用法分析08-15

        JavaScript中push(),join() 函數(shù)實(shí)例詳解09-05

        最常用的20個javascript方法函數(shù)09-10

        JavaScript日期時(shí)間格式化函數(shù)08-29

        簡單介紹php構(gòu)造函數(shù)用法08-31

        JavaScript中常見的字符串操作函數(shù)及用法07-24

        有關(guān)javascript實(shí)現(xiàn)的多個層切換效果通用函數(shù)示例10-07

        JavaScript基于正則表達(dá)式數(shù)字判斷函數(shù)06-14

        常用排序算法之JavaScript實(shí)現(xiàn)代碼段06-04

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码
      3. <sub id="h4knl"><ol id="h4knl"></ol></sub>
        <sup id="h4knl"></sup>
          <sub id="h4knl"></sub>

          <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
          1. <strong id="h4knl"></strong>

          2. 中文字幕乱在线伦视频日韩 | 五月天亚洲综合在线 | 在线高清理伦片a | 午夜人成视频在线男人每天 | 亚洲欧美激情国产综合久久久 | 精品女同一区二区三区免费站 |