我有一个 ArrayController
它观察每个模型特定属性的变化。我用 .observes('content.@each.someprop')
为此目的:
App.ListController = Em.ArrayController.extend({
content: [],
myObserver: function () {
//check changed property
//do stuff if changed to some specific value
}.observes('content.@each.someprop')
});
到目前为止一切顺利 - 当任何模型的属性发生变化时,观察者都会触发。但是,当它启动时,我不知道哪个模型发生了变化——我必须遍历模型并将该属性与存储在其他地方的旧值进行比较才能弄清楚,这是非常笨拙和低效的。我试着检查 arguments
观察者收到,但它们也没有用:console.log(arguments)
从观察者内部给出以下内容:[Class, "content.@each.someprop"]
, 和 console.log(arguments[0].toString())
给出 <App.ListController:ember366>
- Controller 本身和属性字符串。
所以我的问题是:有没有办法在观察数组的 @each
时知道哪个模型发生了变化?属性(property)?
更新
当观察者触发时,我想检查被监视的属性是否已更改为某个特定值,如果是,则执行一些操作。
按照建议我会检查 itemController
现在。
最佳答案
您可以在当前的 ember 中使用 reduceComputed 实现此目的或 arrayComputed .
不过,最好了解您的用例:很可能有比手动创建观察者更好的方法。
关于javascript - Emberjs - 在 @each 中改变的模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15183682/