組合使用構造函數和原型


function Person(name, age, job) {
            this.name = name;
            this.age = age;
            this.job = job;
            this.friends = ['Jack', 'Lee'];
        }
        Person.prototype = {
            constructor: Person,
            sayName:function () {
                return this.name + this.age + this.job;
            }
        };
        var person1 = new Person('a', 100, 'student');
        var person2 = new Person('b', 200, 'teacher');
        //alert(person1.sayName());
        //alert(person2.sayName());//b200
        person1.friends.push('lalala');
        alert(person1.friends);//jack lee lalala
        alert(person2.friends);//jack lee
        alert(person1.sayName == person2.sayName);//true.sayName是原型中的,因為有共享
        alert(person1.friends == person2.friends);//false。因為實例屬性是在構造函數中定義;修改了person1的friends並不會影響person2的friends。因為不具備共享

  


注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
粤ICP备14056181号  © 2014-2021 ITdaan.com