- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个Array of Objects
:
var boxes = [
{ left: 10, top: 20 }, // boxes[0]
{ left: 100, top: 200 } // boxes[1]
];
boxes[0].left = 20; // example of 'set' action
boxes
对象项的每个属性定义通用getter或setter,即使添加了其他项,例如:
boxes.push({ left: 30, top: 40 });
addListener
函数隐式附加到每个对象项,从而将侦听器函数绑定到属性的设置器。像这样:
boxes[0].addListener("left", function(new_value){
console.log("left has been changed to "+new_value);
});
boxes[2].addListener("top", ...
boxes[i]
项目都将像这样填充:
{
left: 10,
top: 20,
set left(val){ /* would trigger every left listener */ },
set top(val){ /* would trigger every top listener */ },
addListener: function(prop, func){ /* ... */ }
}
boxes
数组应与
JSON.stringify()保持可解析,因此:
JSON.stringify(boxes); // would return [{"left":10,"top":20},{"left":100,"top":200}]
最佳答案
经过长时间的尝试和错误,终于找到了一个优雅的解决方案。
1.首先,我们用一些通用的Object.prototype
和addListener(prop, listener)
函数覆盖removeListener(prop, listener)
(每个对象/数组的通用函数),这些函数基本上将给定的侦听器注册到“不可见的” __listeners__
数组中:
Object.defineProperty(Object.prototype, "addListener", {
value: function(prop, listener){
if(!("__listeners__" in this)){
Object.defineProperty(this, "__listeners__", {value: {}, writable: true});
}
if(!(prop in this.__listeners__)) this.__listeners__[prop] = [];
if(this.__listeners__[prop].indexOf(listener) == -1){
this.__listeners__[prop].push(listener);
return true;
} else return false;
}
});
Object.defineProperty(Object.prototype, "removeListener", {
value: function(prop, listener){
if("__listeners__" in this && prop in this.__listeners__){
var index = this.__listeners__[prop].indexOf(listener);
if(index > -1){
this.__listeners__[prop].splice(index, 1);
return true;
} else return false;
} else return false;
}
});
boxes
对象的任何属性/子属性的任何“设置”操作。为此,我们需要设置
Proxies的递归使用。
var boxes = [
{ left: 10, top: 20 }, // boxes[0]
{ left: 100, top: 200 } // boxes[1]
];
var boxes_proxy = new Proxy(boxes);
boxes_proxy[0].left = 20;
console.log(boxes_proxy[0].left); // 20
console.log(boxes[0].left); // 20
boxes_proxy[0].left = 20;
,检测到的动作分为两部分:
boxes_proxy[0].
:在
boxes
上检测到的操作是“获取属性0”,该操作将
boxes[0]
作为默认的“获取”处理程序返回。
.left = 20;
left
的
boxes[0]
属性设置为20,但由于不是同一对象,因此未检测到。要检测它,我们必须在
boxes[0]
上创建另一个代理。
boxes[0].foo.bar[2].font.color
)的问题,我们可以创建
recursiveGetter
和
genericSetter
函数,使
recursiveGetter
返回Proxy而不是其对应的Object / Array。并将任何“设置”动作绑定到触发监听器的
genericSetter
函数:
var recursiveGetter = function(real_object, prop){
if(typeof real_object[prop] == "object"){
var prop_proxy = new Proxy(real_object[prop], {
get: recursiveGetter,
set: genericSetter
});
return prop_proxy;
} else return real_object[prop];
}
var genericSetter = function(real_object, prop, value){
real_object[prop] = value;
if("__listeners__" in real_object && prop in real_object.__listeners__){
real_object.__listeners__[prop].forEach(function(fct){ fct(value); });
}
return true;
}
new Proxy(boxes)
上应用这些getter / setter,它们就会被递归应用:
var boxes_proxy = new Proxy(boxes, { get: recursiveGetter, set: genericSetter });
boxes_proxy[0].addListener("left", function(new_value){
console.log("left has been changed to "+new_value);
});
boxes_proxy[0].left = 20; // "left has been changed to 20"
JSON.stringify(boxes); // [{"left":20,"top":20},{"left":100,"top":200}]
JSON.stringify
仍然适用。
关于javascript - 数组中对象属性的 getter / setter ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39470796/
因此,我需要获取在为其赋值时调用的 setter 的名称。像这样: var b = {}; var a = { set hey(value) { b[] = value; } } 我希望 se
我是 Android 编程的新手(~ 2 个月)有必要为几十个不同的变量设置 getter 吗? 例如—— //Yes I realise that this isn't 'dozens' publi
import Control.Lens import Control.Lens.TH data Foo = Foo { _bar, _baz :: Int } makeLenses ''
我有点困惑:我可以覆盖 setter/getter 但仍然使用 super setter/getter 吗?如果是 - 怎么办? 用例: class A { void set value(num
我有一个接收消息的应用程序。消息中存在可编辑的字段。当字段更改时,应将其保存到数据库中。不幸的是,setter 仅在 setter 的范围内更改给定字段的值。知道为什么会发生这种情况吗?这是 gett
C# 中有没有一种方法可以让 setter 从“某物”继承,这样每次为特定基类及其继承者调用 setter 时,我都可以运行一些代码? 我想做的是在我的基类上有一个名为 IsValid 的 bool
可能是一个我无法解决的非常简单的问题 - 我从 C# 开始,需要使用 getter/setter 方法向数组添加值,例如: public partial class Form1 : Form {
这两个属性实现有什么区别? public override string A { get { return "s"; } set { } } public override strin
是否可以使用 abc.abstractproperty 创建一个具体的 getter 但将 setter 抽象为每个继承类的不同。我为每个子类处理不同的 val 设置。 例如。 @abstractpr
我在某处看到类似下面的内容,想知道它是什么意思。我知道他们是getter和setter,但是想知道为什么字符串Type是这样定义的。谢谢你帮助我。 public string Type { get;
Public class Example { private int number; public Example(int number){ this.number =
假设我有这样的代码: public response MyMethod(Request req) { String id = req.getFirst().geId(); } 我已经模拟了主对
允许这样做: public int Age { get; set; } 但是应用程序是否为变量创建/分配空间?我经常这样做 private int age = 0; public int Age {
我有一个条件,我构造字符串 (finalValue) 的方式是基于我在输入中获得的非空值的数量。所以我想知道是否可以用一个不同的参数为字符串 (finalValue) 重载 setter 方法并根据我
例如,在这段代码中 var o = { set a(value) {this.b = value}, get a() {return this.b} } 是否有可能获得对 o.a 的 sett
我一直在努力了解 getter 和 setter,但没有深入了解。我读过 JavaScript Getters and Setters和 Defining Getters and Setters只是没
我想在我的类中添加一个 getter 和 setter。然而,setter 应该接收一个 querySelector,但 getter 返回一个新类型 pageSections。 我的问题是 gett
使用有什么好处: private var _someProp:String; public function set someProp(value:String):void { _somePr
当从域类调用它时,我想在我的 setter 中执行一些操作,而不是从 hibernate 中调用它时。此外,我正在使用 session 工厂,因此我无法使用 @PostLoad 来触发标志! 有人对此
人员类别: public class Person { private String firstName; private String lastName; public Pe
我是一名优秀的程序员,十分优秀!