[英]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.