假设我有以下JavaScript:
var obj = {
key1 : "it ",
key2 : key1 + " works!"
};
alert(obj.key2);
此错误带有“key1 is not defined”。我试过了
this.key1
this[key1]
obj.key1
obj[key1]
this["key1"]
obj["key1"]
它们似乎从未被定义过。
如何让key2引用key1的值?
假设我有以下JavaScript:
var obj = {
key1 : "it ",
key2 : key1 + " works!"
};
alert(obj.key2);
此错误带有“key1 is not defined”。我试过了
this.key1
this[key1]
obj.key1
obj[key1]
this["key1"]
obj["key1"]
它们似乎从未被定义过。
如何让key2引用key1的值?
这不是JSON。JSON被设计得很简单;允许任意表达式并不简单。
在完整的JavaScript中,我不认为您可以直接这样做。在被称为obj的对象完全构造之前,您不能引用它。所以你需要一个变通办法,一个比我更懂javascript的人可以提供。
在初始化对象之前,不能引用该对象的属性;使用外部变量。
var key1 = "it";
var obj = {
key1 : key1,
key2 : key1 + " works!"
};
此外,这不是一个“JSON对象”;它是一个Javascript对象。JSON是一种用字符串表示对象的方法(它恰好是有效的Javascript代码)。
这不是JSON对象,而是通过对象文字表示法创建的Javascript对象。JSON是一种用于数据交换的文本符号。如果你在处理JavaScript源代码,而不是处理字符串,你就不是在处理JSON。)
在对象初始化式中没有办法引用正在初始化的对象的另一个键,因为在初始化式完成之前没有办法获得对正在创建的对象的引用。(在这种情况下,没有类似的关键字。)
也许您可以考虑删除函数的属性。我的意思是这样的:
Var obj = { Key1: "it ", Key2:函数(){ 返回。Key1 +“works!”; } }; 警报(obj.key2 ());
因为定义obj的语句还没有结束,所以key1还不存在。考虑这个解决方案:
var obj = { key1: "it" };
obj.key2 = obj.key1 + ' ' + 'works!';
// obj.key2 is now 'it works!'
这可以通过使用构造函数而不是文字来实现
var o = new function() {
this.foo = "it";
this.bar = this.foo + " works"
}
alert(o.bar)
你也可以在函数内部引用obj,而不是这样。
var obj = {
key1: "it",
key2: function(){return obj.key1 + " works!"}
};
alert(obj.key2());
一种替代方法是使用getter/setter方法。
例如,如果你只关心读取计算值:
var book = {}
Object.defineProperties(book,{
key1: { value: "it", enumerable: true },
key2: {
enumerable: true,
get: function(){
return this.key1 + " works!";
}
}
});
console.log(book.key2); //prints "it works!"
但是,上面的代码不允许为key2定义另一个值。
所以,如果你想重新定义key2的值,事情就变得有点复杂了。它总是一个计算值。很可能这就是你想要的。
然而,如果您希望能够重新定义key2的值,那么您将需要一个独立于计算的地方来缓存它的值。
有点像这样:
var book = { _key2: " works!" }
Object.defineProperties(book,{
key1: { value: "it", enumerable: true},
_key2: { enumerable: false},
key2: {
enumerable: true,
get: function(){
return this.key1 + this._key2;
},
set: function(newValue){
this._key2 = newValue;
}
}
});
console.log(book.key2); //it works!
book.key2 = " doesn't work!";
console.log(book.key2); //it doesn't work!
for(var key in book){
//prints both key1 and key2, but not _key2
console.log(key + ":" + book[key]);
}
另一个有趣的选择是使用自初始化对象:
var obj = ({
x: "it",
init: function(){
this.y = this.x + " works!";
return this;
}
}).init();
console.log(obj.y); //it works!