简体   繁体   English

重新初始化javascript对象的属性

[英]reinitializing javascript object's properties

In my Javascript drag and drop build app, a variety of buildings can be built. 在我的Javascript拖放构建应用程序中,可以构建各种建筑物。 The specific characteristics of these are all saved in one object, like 这些的具体特征都保存在一个对象中,比如

var buildings = {
house: ['#07DA21',12,12,0,20],
bank: ['#E7DFF2',16,16,0,3],
stadium: ['#000000',12,12,0,1],
townhall: ['#2082A8',20,8,0,1],
etcetera
}

So every building has a number of characteristics, like color, size, look which can be called as buildings[townhall][0] (referring to the color). 因此,每个建筑物都有许多特征,如颜色,大小,外观,可以称为建筑物[townhall] [0](指颜色)。 The object changes as the user changes things. 对象随着用户更改而更改。 When clicking 'reset' however, the whole object should be reset to its initial settings again to start over, but I have no idea how to do that. 但是,当点击“重置”时,整个对象应该重新设置为其初始设置以重新开始,但我不知道该怎么做。 For normal objects it is something like. 对于普通物体,它就像是。

function building() {}
var building = new building();
delete building;
var building2 = new building();

You can easily delete and remake it, so the properties are reset. 您可以轻松删除并重新制作它,以便重置属性。 But my object is automatically initialized. 但是我的对象会自动初始化。 Is there a way to turn my object into something that can be deleted and newly created, without making it very complicating, or a better way to store this information? 有没有办法将我的对象变成可以删除和新创建的东西,而不会使它变得非常复杂,或者更好的方式来存储这些信息?

You can keep initial state as a prototype on an object. 您可以将初始状态保持为对象的原型。

var Base = function(){};
    Base.prototype={a:1,b:2};
var c = new Base();

Now, you can change value of a or b to whatever you want. 现在,您可以将a或b的值更改为您想要的任何值。 To restore, just use 要恢复,只需使用

delete c.a or delete c.b

You will get your initial value back. 您将获得初始值。 Hope this help. 希望这有帮助。

Just use a copy/clone method to restore the original state 只需使用复制/克隆方法即可恢复原始状态

var defaults = {
    foo: "bar"
};
var building;

function reset(){
    building = {};
    for (var key in defaults) {
        if (defaults.hasOwnProperty(key){
            building[key] = defaults[key];
        }
    }
}

Now you can just call reset() whenever you need to have building reset. 现在,只要需要进行building重置,就可以调用reset()

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM