在读取之前设置未定义的 javascript 属性

IT技术 javascript object getter
2021-03-04 14:53:48
var tr={};
tr.SomeThing='SomeThingElse';
console.log(tr.SomeThing); // SomeThingElse
console.log(tr.Other); // undefined

tr.get=function(what){
    if (tr.hasOwnProperty(what)) return tr[what];
    else return what;
};
tr.get('SomeThing') // SomeThingElse
tr.get('Other') // Other

有没有办法让 tr.Other 或 tr['Other'] 以及对象的所有其他未定义属性返回其名称而不是未定义?

3个回答

三种解决方案:

  • 将您的对象实现为 a Proxy,它旨在完全满足您的需求。然而,它只是一个草案,目前仅在 Firefox 的 Javascript 1.8.5 中受支持。 ES6 已标准化,但可能尚未在所有环境中可用。

  • 始终用一组完整的消息填充您的翻译对象。创建该“字典”(服务器端或客户端)时,始终包含所有需要的键。如果不存在翻译,您可以使用备用语言、消息名称或undefined您选择的字符串表示形式

    但是一个不存在的属性应该总是意味着“没有这样的消息”而不是“没有可用的翻译”。

  • 使用带有字符串参数而不是对象属性的 getter 函数。该函数可以在内部字典对象中查找消息,并以编程方式处理未命中。

    我会推荐一个与字典不同的地图对象,以允许“get”和 co 作为消息名称:

var translate = (function(){
    var dict = {
        something: "somethingelse",
        ...
    };
    return {
        exists: function(name) { return name in dict; },
        get: function(name) { return this.exists(name) ? dict[name] : "undefined"; },
        set: function(name, msg) { dict[name] = msg; }
    };
})();

您可以使用对象初始值设定项为您的属性定义一个 getter

var o = {
  a: 7,
  get b() {
    return this.a + 1;
  },
  set c(x) {
    this.a = x / 2;
  }
};

console.log(o.a); // 7
console.log(o.b); // 8 <-- At this point the get b() method is initiated.
o.c = 50;         //   <-- At this point the set c(x) method is initiated
console.log(o.a); // 25

或使用Object.defineProperties()

var o = { a: 0 };

Object.defineProperties(o, {
    'b': { get: function() { return this.a + 1; } },
    'c': { set: function(x) { this.a = x / 2; } }
});

o.c = 10; // Runs the setter, which assigns 10 / 2 (5) to the 'a' property
console.log(o.b); // Runs the getter, which yields a + 1 or 6
Object.prototype.__defineGetter__()弃用。Object.defineProperty()并且{ get propName(){} }是标准的并且不被弃用。正如您所说,您的问题可以用吸气剂来解决。Other如果未定义,您已要求特定属性 ( ) 返回其名称,您是否要求该对象的任何属性返回其名称?如果是这样,请更新您的问题。
2021-04-25 14:53:48
是的,我需要或对象的任何属性返回其名称
2021-05-02 14:53:48
在这种情况下,您将需要Proxy,它甚至更不标准,非常不受支持,并且将来可能会以不兼容的方式进行更改。
2021-05-05 14:53:48
@AlanEvangelista 谢谢,我已经更新了链接并直接在答案中包含了一些 MDN 示例。
2021-05-10 14:53:48
它已被弃用且非标准,并不能解决我的问题
2021-05-12 14:53:48

虽然这种解决方案是不是正是你要找的,一个JavaScript实现的Python的collections.defaultdict类可能有帮助:

var collections = require('pycollections');
var dd = new collections.DefaultDict([].constructor);
console.log(dd.get('missing'));  // []
dd.get(123).push('yay!');
console.log(dd.items()); // [['missing', []], [123, ['yay!']]]