JavaScript原型变量创建引用

javascript prototype variable creates reference

本文关键字:引用 创建 变量 原型 JavaScript      更新时间:2023-09-26

我是面向对象的javascript的新手,因此这个问题可能非常幼稚。

我有:

RIT.test = (function() {
    test.prototype.SRT = {
        someInSRT: 5
    };
    function test() {
    }
    return test;
})();

我正在做以下工作:

    var v1 = new RIT.test();
    var v2 = new RIT.test();
    v1.SRT.someInSRT = 10;
    v1.SRT.someInSRT = 5;
    console.log(v1.SRT.someInSRT);
    console.log(v2.SRT.someInSRT);

为什么两个 v1 的值。SRT.someInSRT 和 v2.SRT.someInSRT都是5?我想象我正在用"new"创建两个单独的实例。

有人可以建议我更好的方法吗?仅供参考,SRT 必须是一个对象。

SRT添加到原型时,将添加对已定义为

{
    someInSRT: 5
}

基于此原型的对象的所有新实例都将共享该引用。因此,v1.SRT === v2.SRT.因此,您对v1.SRT所做的任何更改都将通过 v2.SRT ;

在这种情况下,您需要的是以下内容:

RIT.test = (function() {
    function test() {
        this.SRT = {
            someInSRT: 5
        };
    }
    return test;
})();

这样,从RIT.test派生的所有对象都将具有自己独立的SRT值。

由于您正在创建 RIT.test() 类的 2 个实例,因此它们不能相同。

请考虑以下示例:

var class1 = function(value){
this.number value;
};
class1.prototype.getNumber = function(){
return this.number;
}
var number = new class1(5);
var number2 = new class1();//not value pass to the constructor here...
console.log(number.getNumber());//print 5 because the constructor is reciving a value
console.log(number2.getNumber())//null, since you have not give any value
//since you did not pass any value to the second instance to the constructor