• JavaScript Patterns 3.2 Custom Constructor Functions


    When you invoke the constructor function with new, the following happens inside the function:

    • An empty object is created and referenced by this variable, inheriting the prototype of the function.

    • Properties and methods are added to the object referenced by this.

    • The newly created object referenced by this is returned at the end implicitly (if no other object was returned explicitly).

    var Person = function (name) {
    
        this.name = name;
    
        this.say = function () {
    
            return "I am " + this.name;
    
        };
    
    };   
    
    var adam = new Person("Adam");
    
    adam.say(); // "I am Adam" 

    Note

    reusable members, such as methods, should go to the prototype.

    Person.prototype.say = function () {
    
        return "I am " + this.name;
    
    };

    Constructor's Return Values

    When invoked with new, a constructor function always returns an object inheriting from the constructor's prototype.

    var Objectmaker = function () {
    
        // this `name` property will be ignored
    
        // because the constructor
    
        // decides to return another object instead
    
        this.name = "This is it";
    
        // creating and returning a new object
    
        var that = {};
    
        that.name = "And that's that";
    
        return that;
    
    };
    
    // test
    
    var o = new Objectmaker();
    
    console.log(o.name); // "And that's that"   

    You have the freedom to return any object in your constructors, as long as it's an object. Attempting to return something that's not an object (like a string or a boolean false, for example) will not cause an error but will simply be ignored, and the object referenced by this will be returned instead.

  • 相关阅读:
    关于c语言的一个小bug(c专家编程)
    A10 平板开发一硬件平台搭建
    A10 平板开发二搭建Android开发环境
    hdu
    如何选择发现自己是否适合科研?
    屌丝程序员与房子
    一步一步学数据结构之n--n(Prim算法)
    pat 1049 Counting Ones
    add-strings
    这篇讲PHP的讲的有些道理 & mb_substr & 中文处理
  • 原文地址:https://www.cnblogs.com/haokaibo/p/Custom-Constructor-Functions.html
Copyright © 2020-2023  润新知