4

假设我有一个这样的对象:

var time = {
    'second': 1000,
    'minute': 1000 * 60,
    'hour'  : 1000 * 60 * 60,
    'day'   : 1000 * 60 * 60 * 24,
    'week'  : 1000 * 60 * 60 * 24 * 7
};

我将如何缩短它以便它引用其他键?

我的意思是这样的:

var time = {
    'second': 1000,
    'minute': this.second * 60,
    'hour'  : this.minute * 60,
    'day'   : this.hour   * 24,
    'week'  : this.day    * 7
}

我无法引用每个 using time.foo,因为该变量尚未初始化。我可以简单地将每个添加到一个新命令上,例如time['hour'] = time.minute * 60;,但我宁愿在一个命令中完成。

4

5 回答 5

6

如果您像这样声明它,则不能从自身引用属性,因为属性尚不存在,您可能想尝试不同的方法

var time = {};
time.second = 1000;
time.minute = time.second * 60;
...
于 2012-09-12T21:44:58.320 回答
5
var time = (function(){
    var second = 1000,
        minute = second * 60,
        hour = minute * 60,
        day = hour * 24,
        week = day * 7;
    return {
        'second': second,
        'minute': minute,
        'hour'  : hour,
        'day'   : day,
        'week'  : week
    };
})();

UPD

更短:

var time = (function(){
    var w, d, h, m, s;
    w = (d = (h = (m = (s = 1000) * 60) * 60) * 24) * 7;
    return {
        second: s,
        minute: m,
        hour  : h,
        day   : d,
        week  : w
    };
})();

最后是这个的缩小版:

var time=function(){var a,b,c,d,e;a=(b=(c=(d=(e=1e3)*60)*60)*24)*7;return{second:e,minute:d,hour:c,day:b,week:a}}()
于 2012-09-12T21:47:02.193 回答
3

您不能这样做,因为对象在解析时还不存在。

避免这种情况的唯一方法是创建一个对象,然后一个一个地添加键 - 因此您已经拥有一个具有要重用属性的对象。

于 2012-09-12T21:44:36.447 回答
3

将对象更改为构造函数,您可以这样做:

function Time() {
    this.second = 1000;
    this.minute = this.second * 60;
    this.hour = this.minute * 60;
    this.day = this.hour * 24;
    this.week = this.day * 7;
}

// Use
var time = new Time();
于 2012-09-12T21:45:25.247 回答
1

您可以使用大多数现代浏览器支持的 getters 语法:

var time = {
    'second': 1000,
     get minute () {
       return this.second * 60;
     },
     get hour (){
       return this.minute * 60;
     },
     get day (){
       return this.hour * 24;
     },
     get week (){
       return this.day * 7;
     }
};
于 2012-09-12T22:02:27.303 回答